Delphi'de Klavye Olaylarını Anlama ve İşleme

Klavye olayları ile birlikte fare olayları, bir kullanıcının programınızla etkileşiminin temel unsurlarıdır.

Aşağıda, bir kullanıcının bir Delphi uygulamasındaki tuş vuruşlarını yakalamanızı sağlayan üç etkinlik hakkında bilgi bulunmaktadır: onkeydown, onkeyup ve OnKeyPress.

Aşağı, Yukarı, Basın, Aşağı, Yukarı, Basın...

Delphi uygulamaları klavyeden girişi almak için iki yöntem kullanabilir. Kullanıcının bir uygulamaya bir şey yazması gerekiyorsa, bu girdiyi almanın en kolay yolu Düzenle gibi tuşlara otomatik olarak yanıt veren denetimlerden birini kullanmaktır.

Bununla birlikte, diğer zamanlarda ve daha genel amaçlar için, formlar ve klavye girişini kabul eden herhangi bir bileşen tarafından tanınan üç olayı işleyen bir formda prosedürler oluşturabiliriz. Kullanıcının çalışma zamanında basabileceği herhangi bir tuşa veya tuş kombinasyonuna yanıt vermek üzere bu olayların olay işleyicilerini yazabiliriz.

İşte bu olaylar:

onkeydown - klavyedeki herhangi bir tuşa basıldığında çağrılır
onkeyup - klavyedeki herhangi bir tuş bırakıldığında çağrılır

instagram viewer

OnKeyPress - ASCII karakterine karşılık gelen bir tuşa basıldığında çağrılır

Klavye İşleyicileri

Tüm klavye olaylarının bir tane var parametre ortak. anahtar parametresi klavyedeki tuştur ve basılan tuşun değerine referansla geçmek için kullanılır. Vardiya parametresi ( onkeydown ve onkeyup prosedürler), Shift, Alt veya Ctrl tuşlarının tuş vuruşu ile birleştirilip birleştirilmediğini belirtir.

Gönderen parametresi yöntemi çağırmak için kullanılan denetime başvurur.

prosedür TForm1.FormKeyDown (Gönderen: TObject; var Anahtar: Kelime; Shift: TShiftState);... prosedür TForm1.FormKeyUp (Gönderen: TObject; var Anahtar: Kelime; Shift: TShiftState);... prosedür TForm1.FormKeyPress (Gönderen: TObject; var Anahtar: Char); 

Kullanıcı menü komutlarıyla sağlananlar gibi kısayol veya hızlandırıcı tuşlara bastığında yanıt vermek için olay işleyicilerinin yazılması gerekmez.

Odak Nedir?

Odak, kullanıcı girişini fare veya klavye. Yalnızca odağı olan nesne bir klavye olayı alabilir. Ayrıca, çalışan bir uygulamada belirli bir zamanda form başına yalnızca bir bileşen etkin olabilir veya odaklanabilir.

Gibi bazı bileşenler TImage, TPaintBox, TPanel ve TLabel odak alınamıyor. Genel olarak, bileşenler TGraphicControl odaklanamıyor. Ayrıca, çalışma zamanında görünmeyen bileşenler (TTimer) odak alamaz.

OnKeyDown, OnKeyUp

onkeydown ve onkeyup en düşük düzeyde klavye yanıtı sağlar. Her ikisi de onkeydown ve onkeyup işleyiciler, işlev tuşları ve tuşlarla birlikte kullanılan tüm klavye tuşlarına yanıt verebilir. Vardiya, Alt, ve Ctrl anahtarlar.

Klavye olayları birbirini dışlamaz. Kullanıcı bir tuşa bastığında, onkeydown ve OnKeyPress olaylar oluşturulur ve kullanıcı anahtarı bıraktığında, onkeyup olay oluşturulur. Kullanıcı şu tuşlardan birine bastığında: OnKeyPress algılamaz, sadece onkeydown olayı ve ardından onkeyup Etkinlik.

Bir tuşu basılı tutarsanız, onkeyup olay sonuçta onkeydown ve OnKeyPress olaylar meydana geldi.

OnKeyPress

OnKeyPress, 'g' ve 'G' için farklı bir ASCII karakteri döndürür, ancak onkeydown ve onkeyup büyük ve küçük harf alfa tuşları arasında ayrım yapmayın.

Tuş ve Shift Parametreleri

Beri anahtar parametresi başvuru ile iletilir, olay işleyicisi değişebilir anahtar böylece uygulama etkinliğe katılan farklı bir anahtar görür. Bu, kullanıcıların alfa tuşları yazmasını önlemek gibi, kullanıcının girebileceği karakter türlerini sınırlamanın bir yoludur.

Eğer anahtar içinde ['a'.. 'z'] + ['A'.. 'Z'] sonra Anahtar: = # 0 

Yukarıdaki ifade, anahtar parametresi iki kümenin birleşimindedir: küçük harf karakterler (ör. bir vasıtasıyla z) ve büyük harf karakterler (A-Z). Öyleyse, ifade sıfır karakter değerini anahtar herhangi bir girişi önlemek için Düzenle örneğin, değiştirilmiş anahtarı aldığında.

Alfasayısal olmayan anahtarlar için WinAPI sanal anahtar kodları basılan tuşu belirlemek için kullanılabilir. Windows, kullanıcının basabileceği her tuş için özel sabitler tanımlar. Örneğin, VK_RIGHT Sağ Ok tuşunun sanal anahtar kodudur.

Gibi bazı özel tuşların anahtar durumunu almak için TAB veya Sayfa yukarı, kullanabiliriz GetKeyState Windows API çağrısı. Tuş durumu, tuşun yukarı, aşağı veya geçişli olup olmadığını belirtir (tuşa her basıldığında açık veya kapalı).

Eğer HiWord (GetKeyState (vk_PageUp)) <> 0 sonra
ShowMessage ('PageUp - DOWN')
Başka
ShowMessage ('PageUp - UP'); 

İçinde onkeydown ve onkeyup Etkinlikler, anahtar Windows sanal anahtarını temsil eden imzasız bir Word değeridir. Karakter değerini almak için anahtar, kullanırız Chr işlevi. İçinde OnKeyPress Etkinlik, anahtar bir kömür ASCII karakterini temsil eden değer.

Her ikisi de onkeydown ve onkeyup olaylar, tür Shift parametresini kullanır TShiftState, bir tuşa basıldığında Alt, Ctrl ve Shift tuşlarının durumunu belirlemek için bir dizi bayrak.

Örneğin, Ctrl + A tuşlarına bastığınızda, aşağıdaki önemli olaylar oluşturulur:

 KeyDown (Ctrl) // ssCtrl
KeyDown (Ctrl + A) // ssCtrl + 'A'KeyPress (A) KeyUp (Ctrl + A)

Klavye Olaylarını Forma Yeniden Yönlendirme

Tuş vuruşlarını formun bileşenlerine iletmek yerine form düzeyinde yakalamak için formun KeyPreview özelliği True değerine ( Nesne Denetçisi). Bileşen yine de olayı görüyor, ancak formun önce işlemek için bir fırsatı var - örneğin bazı tuşlara basılmasına izin vermek veya vermemek.

Bir formda birkaç Düzenleme bileşeniniz olduğunu ve Form. OnKeyPress prosedür şöyle görünür:

prosedürTForm1.FormKeyPress (Gönderen: TObject; var Anahtar: Char); başlaEğer anahtar içinde ['0'..'9'] sonra Anahtar: = # 0. son; 

Edit bileşenlerinden birinde Odak, ve KeyPreview formun özelliği False, bu kod yürütülmez. Başka bir deyişle, kullanıcı 5 anahtar 5 karakter odaklanan Düzenle bileşeninde görünecektir.

Ancak, KeyPreview True olarak ayarlandıysa, form OnKeyPress olayı, Düzenle bileşeni basılan anahtarı görmeden önce yürütülür. Yine, kullanıcı 5 tuşuna basarsanız Edit bileşenine sayısal girişi önlemek için Key'e sıfır karakter değerini atar.