VC 各種情況下的窗口句柄的獲取

AfxGetMainWnd
AfxGetMainWnd獲取自身窗口句柄
HWND hWnd = AfxGetMainWnd()->m_hWnd;

GetTopWindow
函數功能:該函數檢查與特定父窗口相聯的子窗口z序(Z序:垂直屏幕的方向,即疊放次序),並返回在z序頂部的子窗口的句柄。
函數原型:HWND GetTopWindow(HWND hWnd);
參數:
  hWnd:被查序的父窗口的句柄。如果該參數爲NULL,函數返回Z序頂部的窗口句柄。
返回值:
    如果函數成功,返回值爲在Z序頂部的子窗口句柄。如果指定的窗口無子窗口,返回值爲NULL。

GetForegroundWindow
函數功能:該函數返回當前系統的前臺窗口的窗口句柄。
函數原型:HWND GetForegroundWindow(VOID)  
返回值:函數返回前臺窗回的句柄。

GetActiveWindow

函數功能:該函數可以獲得與調用該方法的線程的消息隊列相關的活動窗口的窗口句柄(就是取得當前進程的活動窗口的窗口句柄)。
函數原型:HWND GetActiveWindow(VOID)
返回值:返回值是與調用線程的消息隊列相關的活動窗口的句柄。否則,返回值爲NULL。


GetSafeHwnd
函數功能:獲取某個窗口對象(CWnd的派生對象)指針的句柄(HWND)時,最安全的方法是使用GetSafeHwnd()函數。
通過下面的例子來看其理由:
  CWnd *pwnd = FindWindow(“ExploreWClass”,NULL); //希望找到資源管理器
  HWND hwnd = pwnd->m_hwnd; //得到它的HWND
  這樣的代碼當開始得到的pwnd爲空的時候就會出現一個“General protection error”,並關閉應用程序,因爲一般不能對一個NULL指針訪問其成員,如果用下面的代碼:
  CWnd *pwnd = FindWindow(“ExploreWClass”,NULL); //希望找到資源管理器
  HWND hwnd = pwnd->GetSafeHwnd(); //得到它的HWND
  就不會出現問題,因爲儘管當pwnd是NULL時,GetSafeHwnd仍然可以用,只是返回NULL


IsWindowVisible
函數功能:該函數獲得給定窗口的可視狀態。
函數原型:BOOL IsWindowVisible(HWND hWnd);
參數;
  hWnd:被測試窗口的句柄。
返回值:
    如果指定的窗口及其父窗口具有WS_VISIBLE風格,返回值爲非零;如果指定的窗口及其父窗口不具有WS_VISIBLE風格,返回值爲零。由於返回值表明了窗口是否具有Ws_VISIBLE風格,因此,即使該窗口被其他窗口遮蓋,函數返回值也爲非零。
備註:
    窗口的可視狀態由WS_VISIBLE位指示。當設置了WS_VISIBLE位,窗口就可顯示,而且只要窗口具有WS_VISIBLE風格,任何畫在窗口的信息都將被顯示。


IsWindow:
函數功能:該函數確定給定的窗口句柄是否標示一個已存在的窗口。 
函數原型:BOOL IsWindow(HWND hWnd);
參數:
    hWnd:被測試窗口的句柄。
返回值:
    如果窗口句柄標識了一個已存在的窗口,返回值爲TURE;如果窗口句柄未標識一個已存在窗口,返回值爲FALSE。


FindWindow:
HWND FindWindow(LPCSTR lpClassName,LPCSTR lpWindowName );
參數:
lpClassName
  指向一個以null結尾的、用來指定類名的字符串或一個可以確定類名字符串的原子。如果這個參數是一個原子,那麼它必須是一個在調用此函數前已經通過GlobalAddAtom函數創建好的全局原子。這個原子(一個16bit的值),必須被放置在lpClassName的低位字節中,lpClassName的高位字節置零。
lpWindowName
  指向一個以null結尾的、用來指定窗口名(即窗口標題)的字符串。如果此參數爲NULL,則匹配所有窗口名。
返回值:
如果函數執行成功,則返回值是擁有指定窗口類名或窗口名的窗口的句柄。
  如果函數執行失敗,則返回值爲 NULL 。可以通過調用GetLastError函數獲得更加詳細的錯誤信息。


SetWindowText:
至於窗口標題的改變,我們可以通過SetWindowText來實現
注:如果窗口本身屬性是不顯示標題的,這個函數的調用不會影響窗口屬性。
//Set title for application’s main frame window .
AfxGetMainWnd ( ) -> SetWindowText (_T("Application title") )
//Set title for View’s MDI child frame window .
GetParentFrame ( ) -> SetWindowText ("_T ("MDI Child Frame new title") )
//Set title for dialog’s push button control.
GetDigitem (IDC_BUTTON) -> SetWindowText (_T ("Button new title ") )
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章