MoveWindow和SetWindosPos的異同
1.原型
BOOL MoveWindow(
HWND hWnd,
int X,
int Y,
int nWidth, int nHeight,
BOOL bRepaint );
BOOL SetWindowPos(
HWND hWnd,
HWND hWndInsertAfter,
int X, int Y,
int cx, int cy,
UINT uFlags );
2.相同功能:
兩個API都可以移動視窗位置和改變視窗大小,但是如果MoveWindow中的bRepaint參數為FALSE,則父視窗不會被重繪;
而SetWindowPos則會重繪;
3.不同之處
MoveWindow只能移動視窗和改變大小但不能改變視窗的Z序;
SetWindowPos則可以改變視窗Z序、視窗大小、視窗位置、設定是否視窗是否啟用、是否顯示和隱藏、重新計算客戶區等(功能很強大哦);
另外就是如果需要一次性移動多個視窗,則可以用BeginDeferWindowPos/DeferWindowPos/EndDeferWindowPos實現。
本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/zengwh/archive/2009/02/26/3939115.aspx
===================================================================================
另一篇詳細的資料:
===================================================================================
第一種方法:使用SetWindowPos函數
CWnd::SetWindowPosBOOL SetWindowPos( const CWnd* pWndInsertAfter, int x, int y, int cx, int cy,UINT nFlags );
傳回值如果函數成功,則返回非零值;否則返回0。
說明
調用這個成員函數以改變子視窗、快顯視窗和頂層視窗的大小、位置和Z軸次序。視窗在螢幕上按照它們的Z軸次序排序。在Z軸次序上處於頂端的視窗將程式在所有其它視窗的頂部。子視窗的所有座標都是客戶座標(相對於父視窗客戶區的左上方)。視窗可以被移動到Z軸次序的頂部,既可以通過將pWndInsertAfter參數設為&wndTopMost,並確保沒有設定SWP_NOZORDER標誌,也可以通過設定視窗的Z軸次序使它位於所有現存的頂層視窗上方。當一個非頂層視窗被設為頂層視窗時,它擁有的視窗也被設為頂層的。它的擁有者不發生變化。如果頂層視窗被重新置放到Z軸次序的底部(&wndBottom)或任何非頂層視窗之後,則它將不再是頂層視窗。當頂層視窗被變為非頂層視窗時,它所有的擁有者和它擁有的所有視窗都被變為非頂層視窗。如果既沒有指定SWP_NOACTIVE標誌也沒有指定SWP_NOZORDER標誌(這意味著應用程式要求視窗被同時啟用並放入指定的Z軸次序),則pWndInsertAfter參數中指定的值將只在下列環境下適用:l 在pWndInsertAfter參數中既沒有指定&wndTopMost也沒有指定&wndNoTopMost。
這個視窗不是使用中視窗。應用程式不能啟用一個非使用中視窗但同時又不把它帶到Z軸次序的頂部。應用程式可以沒有任何限制地改變使用中視窗的Z軸次序。非頂層視窗可能擁有一個頂層視窗,但是反之則不成立。任何被頂層視窗擁有的視窗(例如對話方塊)都將自己變為頂層視窗,以確保所有被擁有的視窗位於它們的擁有者上方。在Windows 3.1或更新的版本中,可以將視窗移動到Z軸次序的頂部,並通過設定它們的WS_EX_TOPMOST風格而將之鎖定在那裡。這種頂層視窗即使在失去活動狀態以後也會保持頂層位置。例如,選擇WinHelp的Always On Top命令會使說明視窗變為頂層,並且在你返回應用程式之後它還保持可見。要建立一個頂層視窗,應在調用SetWindowPos的時候將pWndInsertAfter參數設為&wndTopMost,或者在建立視窗的時候設定WS_EX_TOPMOST風格。如果Z軸次序中包含了任何具有WS_EX_TOPMOST風格的視窗,則用&wndTopMost移動的視窗將被放到所有非頂層視窗的頂部,但是位於任何頂層視窗的下面。當應用程式啟用一個不具有WS_EX_TOPMOST風格的非使用中視窗時,該視窗將被移動到所有非頂層視窗的上方,但是位於所有頂層視窗的下方。如果在調用SetWindowPos的時候pWndInsertAfter參數被設為&wndBottom,並且CWnd是一個頂層視窗,則該視窗失去頂層狀態(WS_EX_BOTTOM風格被清除),並且系統將視窗放在Z軸次序的底部 。
參數pWndInsertAfter
標識了在Z軸次序上位於這個CWnd對象之前的CWnd對象。這個參數可以是指向CWnd對象的指標,也可以是指向下列值的指標:
wndBottom 將視窗放在Z軸次序的底部。如果這個CWnd是一個頂層視窗,則視窗將失去它的頂層狀態;系統將這個視窗放在其它所有視窗的底部。
wndTop 將視窗放在Z軸次序的頂部。
wndTopMost 將視窗放在所有非頂層視窗的上面。這個視窗將保持它的頂層位置,即使它失去了活動狀態。
wndNoTopMost 將視窗重新置放到所有非頂層視窗的頂部(這意味著在所有的頂層視窗之下)。這個標誌對那些已經是非頂層視窗的視窗沒有作用。有關這個函數以及這些參數的使用規則參見說明部分。
x指定了視窗左邊的新位置。
y指定了視窗頂部的新位置。
cx指定了視窗的新寬度。
cy指定了視窗的新高度。
nFlags指定了大小和位置選項。這個參數可以是下列值的組合:
SWP_DRAWFRAME 圍繞視窗畫出邊框(在建立視窗的時候定義)。
SWP_FRAMECHANGED 向視窗發送一條WM_NCCALCSIZE訊息,即使視窗的大小不會改變。如果沒有指定這個標誌,則僅當視窗的大小發生變化時才發送WM_NCCALCSIZE訊息。
SWP_HIDEWINDOW 隱藏視窗。
SWP_NOACTIVATE 不啟用視窗。如果沒有設定這個標誌,則視窗將被啟用並移動到頂層或非頂層視窗組(依賴於pWndInsertAfter參數的設定)的頂部。
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 保持當前的次序(忽略pWndInsertAfter)。
SWP_SHOWWINDOW 顯示視窗。
第二種方法:使用MoveWindow函數
void CWnd::MoveWindow( int x, int y, int nWidth, int nHeight, BOOL bRepaint = TRUE );
void CWnd::MoveWindow( LPCRECT lpRect, BOOL bRepaint = TRUE );
參數
x指定了CWnd的左邊的新位置。
y指定了CWnd的頂部的新位置。
nWidth指定了CWnd的新寬度。
nHeight指定了CWnd的新高度。
bRepaint指定了是否要重畫CWnd。如果為TRUE,則CWnd象通常那樣在OnPaint訊息處理函數中接收到一條WM_PAINT訊息。如果這個參數為FALSE,則不會發生任何類型的重畫操作。這應用於客戶區、非客戶區(包括標題條和捲軸)和由於CWnd移動而露出的父視窗的任何部分。當這個參數為FALSE的時候,應用程式必須明確地使CWnd和父視窗中必須重畫的部分無效或重畫。
lpRectCRect對象或RECT結構,指定了新的大小和位置。說明這個函數改變視窗的位置和大小。對於頂層的CWnd對象,x和y參數是相對於螢幕的左上方的。對於子物件,它們是相對於父視窗客戶區的左上方的。
MoveWindow函數發送一條WM_GETMINMAXINFO訊息。處理這個訊息時,CWnd得到一個改變最大和最小的視窗預設值的機會。如果傳遞給MoveWindow成員函數的參數超過了這些值,則在WM_GETMINMAXINFO處理函數中可以用最小或最大值來代替這些值。
本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/wirror800/archive/2009/03/16/3994608.aspx