GetWindow

GetWindow

目录导航

函数功能

  该函数返回与指定窗口有特定关系(如Z序或所有者)的窗口句柄。[1]

函数原型

HWND GetWindow(HWND hWnd,UNIT nCmd);  

函数参数

1、hWnd:窗口句柄。要获得的窗口句柄是依据nCmd参数值相对于这个窗口的句柄。

2、nCmd:说明指定窗口与要获得句柄的窗口之间的关系。该参数值可以是下列之一:

(1)GW_CHILD:如果指定窗口是父窗口,则获得的是在Z序顶端的子窗口的句柄,否则为NULL。函数仅检查指定父窗口的子窗口,不检查继承窗口。

(2)GW_ENABLEDPOPUP:(WindowsNT 5.0)返回的句柄标识了属于指定窗口的处于使能状态弹出式窗口(检索使用第一个由GW_HWNDNEXT 查找到的满足前述条件的窗口);如果无使能窗口,则获得的句柄与指定窗口相同。

(3)GW_HWNDFIRST:返回的句柄标识了在Z序最高GetWindow函数GetWindow函数端的相同类型的窗口。如果指定窗口是最高端窗口,则该句柄标识了在Z序最高端的最高端窗口;如果指定窗口是顶层窗口,则该句柄标识了在z序最高端的顶层窗口:如果指定窗口是子窗口,则句柄标识了在Z序最高端的同属窗口。

(4)GW_HWNDLAST:返回的句柄标识了在z序最低端的相同类型的窗口。如果指定窗口是最高端窗口,则该柄标识了在z序最低端的最高端窗口:如果指定窗口是顶层窗口,则该句柄标识了在z序最低端的顶层窗口;如果指定窗口是子窗口,则句柄标识了在Z序最低端的同属窗口。

(5)GW_HWNDNEXT:返回的句柄标识了在Z序中指定窗口下的相同类型的窗口。如果指定窗口是最高端窗口,则该句柄标识了在指定窗口下的最高端窗口:如果指定窗口是顶层窗口,则该句柄标识了在指定窗口下的顶层窗口;如果指定窗口是子窗口,则句柄标识了在指定窗口下的同属窗口。

(6)GW HWNDPREV:返回的句柄标识了在Z序中指定窗口上的相同类型的窗口。如果指定窗口是最高端窗口,则该句柄标识了在指定窗口上的最高端窗口;如果指定窗口是顶层窗口,则该句柄标识了在指定窗口上的顶层窗口;如果指定窗口是子窗口,则句柄标识了在指定窗口上的同属窗口。

(7)GW_OWNER:返回的句柄标识了指定窗口的所有者窗口(如果存在)。

3、返回值:如果函数成功,返回值为窗口句柄;如果与指定窗口有特定关系的窗口不存在,则返回值为NULL。

若想获得更多关于错误的信息,请调用GetLastError函数。 

备注信息

在循环体中调用函数EnumChildWindow比调用GetWindow函数可靠。调用GetWindow函数实现该任务的应用程序可能会陷入死循环或退回一个已被销毁的窗口句柄。  

速查信息

Windows NT:3.1以上版本;Windows:95以上版本;Windows CE:1.0以上版本;头文件:winuser.h;库文件:user32.lib。

应用实例

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Text;

using System.Windows.Forms;

using System.Runtime.InteropServices;

namespace WindowsApplication1

{

    public partial class Form1 : Form

    {

        public Form1()

        {

            InitializeComponent();

        }

        [DllImport("user32.dll", EntryPoint = "FindWindow")]

        public static extern int FindWindow(

            string lpClassName,

windows函数windows函数            string lpWindowName

        );

        [DllImport("user32.dll", EntryPoint = "GetWindow")]//获取窗体句柄,hwnd为源窗口句柄

        /*wCmd指定结果窗口与源窗口的关系,它们建立在下述常数基础上:

              GW_CHILD

              寻找源窗口的第一个子窗口

              GW_HWNDFIRST

              为一个源子窗口寻找第一个兄弟(同级)窗口,或寻找第一个顶级窗口

              GW_HWNDLAST

              为一个源子窗口寻找最后一个兄弟(同级)窗口,或寻找最后一个顶级窗口

              GW_HWNDNEXT

              为源窗口寻找下一个兄弟窗口

              GW_HWNDPREV

              为源窗口寻找前一个兄弟窗口

              GW_OWNER

              寻找窗口的所有者

         */

        public static extern int GetWindow(

            int hwnd,

            int wCmd

        );

[DllImport("user32.dll", EntryPoint = "SetParent")]//设置父窗体

        public static extern int SetParent(

            int hWndChild,

            int hWndNewParent

        );

        [DllImport("user32.dll", EntryPoint = "GetCursorPos")]//获取鼠标坐标

        public static extern int GetCursorPos(

ref POINTAPI lpPoint

        );

        [StructLayout(LayoutKind.Sequential)]//定义与API相兼容结构体,实际上是一种内存转换

        public struct POINTAPI

        {

            public int X;

            public int Y;

        }

        [DllImport("user32.dll", EntryPoint = "WindowFromPoint")]//指定坐标处窗体句柄

        public static extern int WindowFromPoint(

            int xPoint,

            int yPoint

        );

private void timer1_Tick(object sender, EventArgs e)

        {

POINTAPI point = new POINTAPI();//必须用与之相兼容的结构体,类也可以

           

            GetCursorPos(ref point);//获取当前鼠标坐标

            int hwnd = WindowFromPoint(point.X, point.Y);//获取指定坐标处窗口的句柄

            this.label1.Text =point.X.ToString() + ":" + point.Y.ToString() + "-" + hwnd.ToString();//显示效果,此时窗口已经嵌入桌面了

        }

const int GW_CHILD = 5;//定义窗体关系

        private void Form1_Load(object sender, EventArgs e)

        {

            int hDesktop = FindWindow("Progman", null);//获取系统句柄

            hDesktop = GetWindow(hDesktop, GW_CHILD);//获取其子窗口句柄,就是桌面的句柄

            SetParent((int)this.Handle, hDesktop);//设置父窗体,第一个为要被设置的窗口,第二个参数为指定其父窗口句柄[2]

        }

    }

}

相关百科
返回顶部
产品求购 求购