微信公众号制作开发 微信小程序定制开发 网站建设制作 手机app软件开发

您的位置:首页 > 技术观点 > 信息详情

Android中的getWindow()总结

来源:山东鸿软信息科技有限公司  阅读量:456  时间:2016-11-05 23:57
下面对Android中的GetActiveWindow,getWindow,GetTopWindow,GetNextWindow,FindWindow,FlashWindow,ShowWindow做简介,希望对有需要的朋友有所帮助。

1.      GetActiveWindow 


函数功能:该函数可以获得与调用线程的消息队列相关的活动窗口的窗口句柄。


函数原型:HWND GetActiveWindow(VOID)


参数:无。


返回值:返回值是与调用线程的消息队列相关的活动窗口的句柄。否则,返回值为NULL。


2. GetWindow

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

函数原型:HWND GetWindow(HWND hWnd,UNIT nCmd);

参数:

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

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

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

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

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

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

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

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

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

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

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

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


3. GetTopWindow


函数功能:该函数检查与特定父窗口相联的子窗口z序,并返回在z序顶部的子窗口的句柄。


函数原型:HWND GetTopWindow(HWND hWnd);


参数:hWnd:被查序的父窗口的句柄。如果该参数为NULL,函数返回Z序顶部的窗口句柄。


返回值;如果函数成功,返回值为在Z序顶部的子窗口句柄。如果指定的窗口无子窗返回值为NULL。


 


4.GetNextWindow


 


函数功能:该函数返回z序中的前一个或后一个窗口的句柄。下一窗口在指定窗口的下面,前一窗口则在上面。如果指定的窗口是顶端窗口,该函数返回下一个(或前一个)顶端窗口的句柄。如果指定的窗口是顶层窗口,函数返回下一个(或前一个)顶层窗口的句柄。如果函数是子窗口,则函数搜索下一个或前一个子窗口的句柄。


函数原型:HWND GetNextWindow(HWND hWnd,UNIT wCmd);


参数:


hWnd:一个窗口的句柄。窗口句柄在wCmd参数的基础上获得的相对于这个窗口的句柄。


wCmd:指明窗口返回的是前一窗口的句柄还是后一窗口的句柄。该参数可以是下列两个值之一:


  GW_HWNDNEXT:返回在给定窗口的下面窗口的句柄。


  GW_HWNDPREV:返回在给定窗口的上面窗口的句柄。


  GW_HWNDFIRST = 0;


  GW_HWNDLAST = 1;


  GW_HWNDNEXT = 2;


  GW_HWNDPREV = 3;


  GW_OWNER = 4;


  GW_CHILD = 5;


返回值:如果函数成功,返回值是前一窗口(或后一窗口)的句柄。如果前后窗口不存在,则返回值为NULL。若想获得更多错误信息,请调用GetLastError函数。


 


5. FindWindow


 


参数表:


lpClassName


指向一个以null结尾的、用来指定类名的字符串或一个可以确定类名字符串的原子。如果这个参数是一个原子,那么它必须是一个在调用此函数前已经通过GlobalAddAtom函数创建好的全局原子。这个原子(一个16bit的值),必须被放置在lpClassName的低位字节中,lpClassName的高位字节置零。


如果该参数为null时,将会寻找任何与lpWindowName参数匹配的窗口。


pWindowName


指向一个以null结尾的、用来指定窗口名(即窗口标题)的字符串。如果此参数为NULL,则匹配所有窗口名。


返回值:


如果函数执行成功,则返回值是拥有指定窗口类名或窗口名的窗口的句柄。


如果函数执行失败,则返回值为 NULL 。可以通过调用GetLastError函数获得更加详细的错误信息。



6. FlashWindow


 


函数原型:


DeclareFunction FlashWindow Lib "user32" Alias "FlashWindow"(ByVal hwnd As Long, ByVal bInvert As Long) As Long


函数说明:


闪烁显示指定窗口。这意味着窗口的标题和说明文字会发生变化,似乎从活动切换到非活动状态、或反向切换。通常对不活动的窗口应用这个函数,引起用户的注意


返回值:


Long,如窗口在调用前处于活动状态,则返回TRUE(非零)。


参数,类型及说明:


hwnd:Long,要闪烁显示的窗口的句柄。


bInvert:Long,TRUE(非零)表示切换窗口标题;FALSE返回最初状态。


注解:


该函数通常与一个计数器组合使用,生成连续的闪烁效果。在windows nt及windows for workgroup中,bInvert参数会被忽略。但在windows 95中不会忽略。


 


7. ShowWindow


hWnd:指窗口句柄。


  nCmdShow:指定窗口如何显示。如果发送应用程序的程序提供了STARTUPINFO结构,则应用程序第一次调用ShowWindow时该参数被忽略。否则,在第一次调用ShowWindow函数时,该值应为在函数WinMain中nCmdShow参数。在随后的调用中,该参数可以为下列值之一:


  SW_FORCEMINIMIZE:在WindowNT5.0中最小化窗口,即使拥有窗口的线程被挂起也会最小化。在从其他线程最小化窗口时才使用这个参数。


  SW_HIDE:隐藏窗口并激活其他窗口。


  SW_MAXIMIZE:最大化指定的窗口。


  SW_MINIMIZE:最小化指定的窗口并且激活在Z序中的下一个顶层窗口。


  SW_RESTORE:激活并显示窗口。如果窗口最小化或最大化,则系统将窗口恢复到原来的尺寸和位置。在恢复最小化窗口时,应用程序应该指定这个标志。


  SW_SHOW:在窗口原来的位置以原来的尺寸激活和显示窗口。


  SW_SHOWDEFAULT:依据在STARTUPINFO结构中指定的SW_FLAG标志设定显示状态,STARTUPINFO结构是由启动应用程序的程序传递给CreateProcess函数的。


  SW_SHOWMAXIMIZED:激活窗口并将其最大化。


  SW_SHOWMINIMIZED:激活窗口并将其最小化。


  SW_SHOWMINNOACTIVATE:窗口最小化,激活窗口仍然维持激活状态。


  SW_SHOWNA:以窗口原来的状态显示窗口。激活窗口仍然维持激活状态。


  SW_SHOWNOACTIVATE:以窗口最近一次的大小和状态显示窗口。激活窗口仍然维持激活状态。


  SW_SHOWNORMAL:激活并显示一个窗口。如果窗口被最小化或最大化,系统将其恢复到原来的尺寸和大小。应用程序在第一次显示窗口的时候应该指定此标志。


返回值


  如果窗口当前可见,则返回值为非零。如果窗口当前被隐藏,则返回值为零。


  (参考信息MSND)


  Return Values


  If the window was previously visible, thereturn value is nonzero.


  If the window was previously hidden, thereturn value is zero.


备注


  应用程序第一次调用ShowWindow时,应该使用WinMain函数的nCmdshow参数作为它的nCmdShow参数。在随后调用ShowWindow函数时,必须使用列表中的一个给定值,而不是由WinMain函数的nCmdSHow参数指定的值。


  正如在nCmdShow参数中声明的,如果调用应用程序的程序使用了在STARTUPINFO结构中指定的信息来显示窗口,则在第一次调用ShowWindow函数时nCmdShow参数就被忽略。在这种情况下,ShowWindow函数使用STARTUPINFO结构中的信息来显示窗口。在随后的调用中,应用程序必须调用ShowWindow函数(将其中nCmdShow参数设为SW_SHOWDEFAULT)来使用由程序调用该应用程序时提供的启动信息。这个处理在下列情况下发生:


  应用程序通过调用带WS_VISIBLE标志的函数来创建它们的主窗口函数;


  应用程序通过调用清除了WS_VISIBLE标志的CreateWindow函数来创建主窗口函数,并且随后调用带SW_SHOW标志的ShowWindow函数来显示窗口;


  Windows CE:nCmdShow参数不支持下列值:


  SW_MAXIMINZE;SW_MINIMIZE;SW_RESTORE;SW_SHOWDEFAULT


  SW_SHOWMAXIMIZED;SW_SHOWMINIMIZED;SW_SHOWMININOACTIVATE


成为您更加专业的技术合伙人

网站建设 | APP开发 | 产品服务 | 技术观点 | 关于我们      客服电子邮箱:1828087588@qq.com  客服QQ:1828087588、1421667633  电话:151-6502-2080

Copyright © 2016-2024 山东鸿软信息科技有限公司 版权所有 https://www.greatsoft.cn 鲁ICP备16026454号