使用鍵盤的概觀 (Windows Forms .NET)
在 Windows Forms 中,使用者輸入會以 Windows 訊息的形式傳送至應用程式。 有一系列的可覆寫方法會在應用程式、表單和控制層級處理這些訊息。 這些方法在接收到鍵盤訊息時就會引發事件,而這些事件經處理後將可取得鍵盤輸入的相關資訊。 在許多情況下,Windows Forms 應用程式只要處理這些事件,就能處理所有使用者輸入。 在其他情況下,應用程式可能需要覆寫處理訊息的其中一種方法,以在應用程式、表單或控制項接收到特定訊息之前加以攔截。
鍵盤事件
所有 Windows Forms 控制項都會繼承一組與滑鼠和鍵盤輸入相關的事件。 例如,控制項可以處理 KeyPress 事件以確定按下的按鍵的字元碼。 如需詳細資訊,請參閱使用鍵盤事件。
處理使用者輸入訊息的方法
表單和控制項可以存取 IMessageFilter 介面和一組可覆寫的方法,以處理訊息佇列中不同點位的 Windows 訊息。 這些方法都有 Message 參數,會封裝 Windows 訊息的低階詳細資料。 您可以實作或覆寫這些方法以檢查訊息,然後取用訊息或將其傳遞給訊息佇列中的下一個取用者。 下表顯示處理 Windows Forms 中所有 Windows 訊息的方法。
方法 | 注意 |
---|---|
PreFilterMessage | 此方法會攔截已在應用層級排入佇列 (也稱為已發佈) 的 Windows 訊息。 |
PreProcessMessage | 此方法會在 Windows 訊息進行處理之前,在表單和控制項層級加以攔截。 |
WndProc | 此方法會在表單和控制項層級處理 Windows 訊息。 |
DefWndProc | 此方法會在表單和控制層級執行 Windows 訊息的預設處理。 這會提供視窗的基本功能。 |
OnNotifyMessage | 此方法會在訊息進行處理之後,在表單和控制項層級加以攔截。 必須設定 EnableNotifyMessage 樣式位元,才能呼叫此方法。 |
鍵盤和滑鼠訊息也會由一組額外的、前述訊息類型特有的可覆寫方法進行處理。 如需詳細資訊,請參閱前置處理按鍵一節。 .
金鑰的類型
Windows Forms 會將鍵盤輸入視為由位元 Keys 列舉代表的虛擬按鍵碼。 使用 Keys 列舉,您可以結合一系列已按下的按鍵來產生單一值。 這些值對應於伴隨 WM_KEYDOWN 和 WM_SYSKEYDOWN 訊息的值。 您可以藉由處理 KeyDown 或 KeyUp 事件來偵測大部分的實體按鍵操作。 字元按鍵是 Keys 列舉的子集,並對應至伴隨 WM_CHAR 和 WM_SYSCHAR 訊息的值。 如果按下的按鍵組合產生了字元,您可以藉由處理 KeyPress 事件來偵測字元。
鍵盤事件的順序
如先前所列,控制項上可能發生有 3 鍵盤相關事件。 下列序列顯示事件的一般順序︰
- 使用者按 "a" 鍵,此鍵會經過前置處理、分派,並發生 KeyDown 事件。
- 使用者按住 "a" 鍵,此鍵會經過前置處理、分派,並發生 KeyPress 事件。 當使用者按住一個按鍵時,此事件會發生很多次。
- 使用者放開 "a" 鍵,此鍵會經過前置處理、分派,並發生 KeyUp 事件。
前置處理按鍵
如同其他訊息,鍵盤訊息會在表單或控制項的 WndProc 方法中進行處理。 不過,在處理鍵盤訊息之前,PreProcessMessage 方法會呼叫一或多個可覆寫的方法,以處理特殊字元按鍵與實體按鍵。 您可以覆寫這些方法,以在控制項處理訊息之前,先偵測並篩選特定按鍵。 下表顯示正在執行的動作以及發生的相關方法 (依方法的發生順序顯示)。
KeyDown 事件前置處理
動作 | 相關方法 | 備註 |
---|---|---|
檢查命令按鍵,例如快速鍵或功能表捷徑。 | ProcessCmdKey | 這個方法會處理命令按鍵,其優先於一般按鍵。 如果此方法傳回 true ,就不會發送按鍵訊息,也不會發生按鍵事件。 如果傳回 false ,則會呼叫 IsInputKey. |
檢查需要前置處理的特殊按鍵,或應該引發 KeyDown 事件並分派至控制項的標準字元按鍵。 | IsInputKey | 如果此方法傳回 true ,則表示控制項是一般字元並且引發 KeyDown 事件。 若為 false ,則會呼叫 ProcessDialogKey。 注意:若要確保控制項會取得按鍵或按鍵組合,您可以處理 PreviewKeyDown 事件,並且為您要的一或多個按鍵將 PreviewKeyDownEventArgs 的 IsInputKey 設定為 true 。 |
檢查導覽鍵 (ESC、TAB、Return 或方向鍵)。 | ProcessDialogKey | 這個方法會處理運用控制項內特殊功能的實體按鍵,例如在控制項與其父代之間切換焦點。 如果最接近的控制項未處理按鍵,則會在父控制項上呼叫 ProcessDialogKey,以此類推到階層中的最上層控制項。 如果此方法傳回 true ,則已完成前置處理,而不會產生按鍵事件。 如果傳回 false ,就會發生 KeyDown 事件。 |
KeyPress 事件的前置處理
動作 | 相關方法 | 備註 |
---|---|---|
查看按鍵是否為應由控制項處理的標準字元 | IsInputChar | 如果此字元是標準字元,這個方法會傳回 true ,就會引發 KeyPress 事件,而且不會發生任何進一步的前置處理。 否則將會呼叫 ProcessDialogChar。 |
查看此字元是否為助憶鍵 (例如按鈕上 &OK) | ProcessDialogChar | 此方法類似於 ProcessDialogKey,會呼叫控制項階層。 如果控制項是容器控制項,它會藉由對本身與其子控制項呼叫 ProcessMnemonic 來檢查助憶鍵。 如果 ProcessDialogChar 傳回 true ,則不會發生 KeyPress 事件。 |
處理鍵盤訊息
在鍵盤訊息送達表單或控制項的 WndProc 方法之後,便會由一組可覆寫的方法進行處理。 每種方法都會傳回 Boolean 值,以指定控制項是否已處理和取用鍵盤訊息。 如果其中一個方法傳回 true
,則會將訊息視為已處理,而不會傳遞給控制項的基底或父代做進一步處理。 否則,訊息會留在訊息佇列中,而且可能會由控制項的基底或父代中的另一個方法所處理。 下表顯示處理鍵盤訊息的方法。
方法 | 注意 |
---|---|
ProcessKeyMessage | 此方法會處理控制項的 WndProc 方法收到的所有鍵盤訊息。 |
ProcessKeyPreview | 此方法會將鍵盤訊息傳送至控制項的父代。 如果 ProcessKeyPreview 傳回 true ,則不會產生任何索引鍵事件,否則會呼叫 ProcessKeyEventArgs。 |
ProcessKeyEventArgs | 此方法會視需要引發 KeyDown、KeyPress 和 KeyUp 事件。 |
覆寫鍵盤方法
若已前置處理及處理鍵盤訊息,有許多方法可用於覆寫;不過,有些方法是更好的選擇 (相較於其他方法)。 下表顯示您可能想要完成的工作,以及覆寫鍵盤方法的最佳方式。 如需覆寫方法的詳細資訊,請參閱繼承 (C# 程式設計手冊) 或繼承 (Visual Basic)
Task | 方法 |
---|---|
攔截瀏覽鍵並引發 KeyDown 事件。 例如,您希望在文字方塊中處理 TAB 和 Return 鍵。 | 覆寫 IsInputKey。 注意:或者,您可以處理 PreviewKeyDown 事件,並且針對您想要的一或多個索引鍵將 PreviewKeyDownEventArgs 的 IsInputKey 設定為 true 。 |
在控制項上執行特殊輸入或導覽處理。 例如,您想使用清單控制項中的方向鍵來變更所選的項目。 | 覆寫 ProcessDialogKey |
攔截瀏覽鍵並引發 KeyPress 事件。 例如,在微調方塊控制項中,您想要多次按方向鍵以加快項目的進度。 | 覆寫 IsInputChar。 |
在 KeyPress 事件期間執行特殊輸入或瀏覽處理。 例如,在清單控制項中按住 "r" 按鍵,可略過以字母 r 開頭的項目。 | 覆寫 ProcessDialogChar |
執行自訂助憶鍵處理;例如,您想要處理工具列內含主控描繪按鈕上的助憶鍵。 | 覆寫 ProcessMnemonic。 |