共用方式為


GetWindowTextW 函式 (winuser.h)

將指定視窗標題列的文字複製到緩衝區中(如果有的話)。 如果指定的視窗是控制件,則會複製控制的文字。 不過,GetWindowText 無法擷取另一個應用程式中控件的文字。

語法

int GetWindowTextW(
  [in]  HWND   hWnd,
  [out] LPWSTR 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

例子

如需範例,請參閱 傳送訊息

注意

winuser.h 標頭會將 GetWindowText 定義為別名,根據 UNICODE 預處理器常數的定義,自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程序代碼,可能會導致編譯或運行時間錯誤不符。 如需詳細資訊,請參閱函式原型的 慣例。

要求

要求 價值
最低支援的用戶端 Windows 2000 Professional [僅限傳統型應用程式]
支援的最低伺服器 Windows 2000 Server [僅限傳統型應用程式]
目標平臺 窗戶
標頭 winuser.h (包括 Windows.h)
連結庫 User32.lib
DLL User32.dll
API 集 ext-ms-win-ntuser-window-l1-1-4 (在 Windows 10 版本 10.0.14393 中引進)

另請參閱

概念

GetWindowTextLength

參考

SetWindowText

WM_GETTEXT

Windows