SetWindowPos小记

来源:互联网 发布:海豚动态壁纸软件 编辑:程序博客网 时间:2024/06/01 09:51

   平时对这些函数都是简单用用,没怎么研究,今天看到了就大概的总结下,方便以后查阅。


功能描述:


     Changes the size, position, and Z order of a child, pop-up, or top-level window. These windows are ordered according to their appearance on the screen. The topmost window receives the highest rank and is the first window in the Z order.

        SetWindowPos函数功能是将一个窗口在三维空间中移动,利用它,你可以改变一个窗口的位置,甚至可以在Z轴上改变(Z轴决定了一个窗口和其它窗口的前后关系),你还可以改变窗口的尺寸。为了实现TopMost类型的窗口,我们只需调用该函数,将窗口放在所有窗口的前面并永远保持在最前面即可。

该函数改变一个子窗口,弹出式窗口或顶层窗口的尺寸,位置和Z序。 子窗口,弹出式窗口,及顶层窗口根据它们在屏幕上出现的顺序排序、顶层窗口设置的级别最高,并且被设置为Z序的第一个窗口。

BOOL WINAPI SetWindowPos(  __in      HWND hWnd,  __in_opt  HWND hWndInsertAfter,  __in      int X,  __in      int Y,  __in      int cx,  __in      int cy,  __in      UINT uFlags);


函数参数:


     hWnd:   窗口句柄。

  hWndlnsertAfter: 在z序中的位于被置位的窗口前的窗口句柄。该参数必须为一个窗口句柄,或下列值之一:
  • HWND_BOTTOM:[1]将窗口置于窗口列表的底部。如果参数hWnd标识了一个顶层窗口,则窗口失去顶级位置,并且被置在其他窗口的底部。
  • HWND_NOTOPMOST:[-2]将窗口置于所有非顶层窗口之上(即在所有顶层窗口之后)。如果窗口已经是非顶层窗口则该标志不起作用。位于任何最顶窗口的后面。 
  • HWND_TOP:  [0]将窗口置于本线程窗口的顶部。
  • HWND_TOPMOST:  [-1]将窗口置于所有非顶层窗口之上。即使窗口未被激活窗口也将保持顶级位置。位于任何最顶窗口的前面 。
  x:以客户坐标指定窗口新位置的左边界。
  Y:以客户坐标指定窗口新位置的顶边界。
  cx:以像素指定窗口的新的宽度。
  cy:以像素指定窗口的新的高度。
  uFlags:  窗口尺寸和定位的标志。该参数可以是下列值的组合:
  • SWP_ASNCWINDOWPOS:如果调用进程不拥有窗口,系统会向拥有窗口的线程发出需求。这就防止调用线程在其他线程处理需求的时候发生死锁。
  • SWP_DEFERERASE:防止产生WM_SYNCPAINT消息。
  • SWP_DRAWFRAME:在窗口周围画一个边框(定义在窗口类描述中)。
  • SWP_FRAMECHANGED:给窗口发送WM_NCCALCSIZE消息,即使窗口尺寸没有改变也会发送该消息。如果未指定这个标志,只有在改变了窗口尺寸时才发送WM_NCCALCSIZE。
  • SWP_HIDEWINDOW;隐藏窗口。
  • SWP_NOACTIVATE:不激活窗口。如果未设置标志,则窗口被激活,并被设置到其他最高级窗口或非最高级组的顶部(根据参数hWndlnsertAfter设置)。
  • SWP_NOCOPYBITS:清除客户区的所有内容。如果未设置该标志,客户区的有效内容被保存并且在窗口尺寸更新和重定位后拷贝回客户区。
  • SWP_NOMOVE:维持当前位置(忽略X和Y参数)。
  • SWP_NOOWNERZORDER:不改变z序中的所有者窗口的位置。
  • SWP_NOREDRAW:不重画改变的内容。如果设置了这个标志,则不发生任何重画动作。适用于客户区和非客户区(包括标题栏和滚动条)和任何由于窗回移动而露出的父窗口的所有部分。如果设置了这个标志,应用程序必须明确地使窗口无效并区重画窗口的任何部分和父窗口需要重画的部分。
  • SWP_NOREPOSITION;与SWP_NOOWNERZORDER标志相同。
  •  SWP_NOSENDCHANGING:防止窗口接收WM_WINDOWPOSCHANGING消息。
  • SWP_NOSIZE:维持当前尺寸(忽略cx和Cy参数)。
  • SWP_NOZORDER:维持当前Z序(忽略hWndlnsertAfter参数)。
  • SWP_SHOWWINDOW:显示窗口。


返回值:

 

     如果函数成功,返回值为非零;如果函数失败,返回值为零。若想获得更多错误消息,请调用GetLastError函数。