WinForm中KeyDown,KeyPress和KeyUp的順序與區(qū)別解析
WinForm中的鍵盤按鍵有KeyDown,KeyPress和KeyUp事件。那么它們的順序以及區(qū)別在哪里呢?本文就此作出如下分析:
一、順序:
根據(jù)MSDN所講,三者的順序是:KeyDown>KeyPress>KeyUp.
二、區(qū)別:
KeyDown和KeyPress很接近,都是在按鍵按下時候先后發(fā)生。KeyUp是放掉某個鍵之后發(fā)生的事件。
三、KeyDown和KeyPress:
KeyDown的事件中屬性是KeyEventArgs,其中包含三個重要屬性:
1)KeyCode(返回一個Keys的枚舉,可以檢測除ScrollLock和NumLock之外的其它鍵值)。
2)KeyValue(等同于KeyCode,只不過是int類型)。
3)KeyData(這個MSDN沒有說清楚,不太容易理解。就我做實驗,其實是一個檢測Ctrl,Shift或者Alt加其他鍵的時候(組合鍵!)可以都被檢測出來。相對而言,1)和2)只能檢測一個鍵值,不能檢測組合鍵)。
這里給出檢測組合鍵的例子(注意,先按下Shift,Alt或者Ctrl,然后其他鍵按下去)
private void Form1_KeyDown(object sender, KeyEventArgs e) { if (e.KeyData==(Keys.A|Keys.Shift)) { MessageBox.Show("按下了Shift+A!"); } }
通常,KeyUp記錄組合鍵的順序一定和KeyDown相反(比如你Shift+A,那么KeyUp中是A+Shift)。不過就檢測組合鍵無關(guān)其順序。
其余檢測方法:
e.Modifiers(只記錄Ctrl,Shift和Alt),加e.KeyChar等判斷:
private void Form1_KeyDown(object sender, KeyEventArgs e) { if (e.Modifiers == Keys.Shift && e.KeyCode == Keys.A) { MessageBox.Show("按下了Shift+A"); } }
KeyEventArgs自身就有Alt,Control和Shift,因此還可以這樣簡化:
private void Form1_KeyDown(object sender, KeyEventArgs e) { if (e.Shift && e.KeyCode == Keys.A) { MessageBox.Show("按下了Shift+A"); } }
3)注意!Alt,Control或者Shift有左右之分。因此檢測左右的話用第三種方法不可能(KeyEventArgs不判斷左右,可以使用1或者2方法,借助Keys枚舉即可)。
4)如果是要做類似“快捷鍵”(譬如多窗口窗體,父窗口中按下某組合鍵彈出子窗口,建議把父窗口的KeyPreview設(shè)置True,這樣窗口比其內(nèi)部所有的子控件優(yōu)先得到事件觸發(fā))。
5)ShiftKey和Shift的區(qū)別:
Shift:不能單獨作為判斷使用,必須加另外一個字母鍵作為組合鍵時候使用。
Shiftkey:單獨按下Shift鍵(沒有其它組合鍵)時候判斷使用。(同理:LShiftKey和RShiftKey)。
相關(guān)文章
C# 中的 IReadOnlyDictionary 和 IReadOnlyLis
C# 中的IReadOnlyDictionary和IReadOnlyList是接口,用于表示只讀的字典和只讀的列表,這些接口提供了對集合的只讀訪問權(quán)限,即不允許對集合進行修改操作,這篇文章主要介紹了C# 中的 IReadOnlyDictionary 和 IReadOnlyList實例詳解,需要的朋友可以參考下2024-03-03詳解C# List<T>的Contains,Exists,Any,Where性能對比
這篇文章主要介紹了詳解C# List<T>的Contains,Exists,Any,Where性能對比,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12C#將圖片存放到SQL SERVER數(shù)據(jù)庫中的方法
這篇文章主要介紹了C#將圖片存放到SQL SERVER數(shù)據(jù)庫中的方法,以實例形式較為詳細的分析了C#保存圖片到SQL Server數(shù)據(jù)庫的具體步驟與相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-09-09C#歸并排序的實現(xiàn)方法(遞歸,非遞歸,自然歸并)
C#歸并排序的實現(xiàn)方法(遞歸,非遞歸,自然歸并),需要的朋友可以參考一下2013-04-04