CWnd::SetWindowPos的注意事项
函数原型:
BOOL CWnd::SetWindowPos
(
const CWnd* pWndInsertAfter, //插入的地方
int x, //水平坐标
int y, //垂直坐标
int cx, //宽
int cy, //高
UINT nFlags //窗口定位标识
);
说明:
这个函数能改变窗口的大小、位置和设置子窗口、弹出窗口或顶层窗口的排列顺序。
返回值:
返回值BOOL类型,如果返回值非零表示成功,返回零表示失败。
参数表:
参数类型及说明
hWndInsertAfter HWND,置于hwnd前面的窗口句柄。这个参数必须是窗口的句柄或是下面的值之一:
wndBottom 将窗口置于其它所有窗口的底部
wndTop 将窗口置于它所有窗口的顶部
wndTopMost 将窗口置于其它所有窗口的顶部,并位于任何最顶部窗口的前面。即使这个窗口不是活动窗口,也维持最顶部状态
wndNoTopMost 将窗口置于其它所有窗口的顶部,并位于任何最顶部窗口的后面。如果这个窗口非顶部窗口,这个标记对该窗口并不产生影响
x: int,指定窗口新的X坐标
Y: int,指定窗口新的Y坐标
cx: int,指定窗口新的宽度
cy: int,指定窗口新的高度
nFlags: UINT,指定窗口状态和位置的标记。
如下将窗口置顶,并且不改变窗口的位置与大小
this->SetWindowPos(&wndTopMost, 0, 0, 0, 0, SWP_NOSIZE|SWP_NOMOVE);
注意:
this->SetWindowPos(NULL, 0, 0, 0, 0, SWP_NOSIZE|SWP_NOMOVE);
这样的代码会造成不可预知的问题,因为SetWindowPos函数的第一个参数需要传入一个指针,
如果传入空,会造成稀奇古怪的问题,正确的做法如下:
this->SetWindowPos(NULL, 0, 0, 0, 0, SWP_NOSIZE|SWP_NOMOVE|SWP_NOZORDER);