GetWindowTextA 函式 (winuser.h)
如果指定視窗的標題列有一個) ,則會將指定視窗標題 (欄的文字複製到緩衝區中。 如果指定的視窗是控制件,則會複製控制的文字。 不過, GetWindowText 無法擷取另一個應用程式中控件的文字。
語法
int GetWindowTextA(
[in] HWND hWnd,
[out] LPSTR lpString,
[in] int nMaxCount
);
參數
[in] hWnd
類型: HWND
包含文字之視窗或控件的句柄。
[out] lpString
類型: LPTSTR
將接收文字的緩衝區。 如果字串長度或超過緩衝區,則會以 Null 字元截斷字串並終止。
[in] nMaxCount
類型: int
要複製到緩衝區的最大字元數,包括 Null 字元。 如果文字超過此限制,則會被截斷。
傳回值
類型: int
如果函式成功,則傳回值是複製字串的長度,不包含終止的 Null 字元。 如果視窗沒有標題列或文字、標題列是空的,或是視窗或控件句柄無效,則傳回值為零。 若要取得擴充的錯誤資訊,請呼叫 GetLastError。
此函式無法擷取另一個應用程式中編輯控件的文字。
備註
如果目標視窗是由目前進程所擁有, GetWindowText 會導致 WM_GETTEXT 訊息傳送至指定的視窗或控件。 如果目標視窗是由另一個進程所擁有,而且具有 標題,GetWindowText 會擷取視窗 標題 文字。 如果窗口沒有 標題,則傳回值為 null 字串。 此行為是設計所致。 如果擁有目標窗口的進程沒有回應,它可讓應用程式呼叫 GetWindowText ,而不會變成沒有回應。 不過,如果目標視窗沒有回應,而且它屬於呼叫的應用程式, GetWindowText 會導致呼叫應用程式變得沒有回應。
若要在另一個進程中擷取控件的文字,請直接傳送 WM_GETTEXT 訊息,而不是呼叫 GetWindowText。
範例
下列範例程式代碼示範 GetWindowTextA 的呼叫。
hwndCombo = GetDlgItem(hwndDlg, IDD_COMBO);
cTxtLen = GetWindowTextLength(hwndCombo);
// Allocate memory for the string and copy
// the string into the memory.
pszMem = (PSTR) VirtualAlloc((LPVOID) NULL,
(DWORD) (cTxtLen + 1), MEM_COMMIT,
PAGE_READWRITE);
GetWindowText(hwndCombo, pszMem,
cTxtLen + 1);
若要查看內容中的這個範例,請參閱 傳送訊息。
注意
winuser.h 標頭會將 GetWindowText 定義為別名,根據 UNICODE 預處理器常數的定義,自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程序代碼,可能會導致編譯或運行時間錯誤不符。 如需詳細資訊,請參閱 函式原型的慣例。
規格需求
需求 | 值 |
---|---|
最低支援的用戶端 | Windows 2000 專業版 [僅限傳統型應用程式] |
最低支援的伺服器 | Windows 2000 Server [僅限傳統型應用程式] |
目標平台 | Windows |
標頭 | winuser.h (包括 Windows.h) |
程式庫 | User32.lib |
Dll | User32.dll |
API 集合 | ext-ms-win-ntuser-window-l1-1-4 (於 Windows 10 10.0.14393 版) |
另請參閱
概念
參考