Monday, August 24, 2020
Understanding and Processing Keyboard Events in Delphi
Comprehension and Processing Keyboard Events in Delphi Console occasions, alongside mouse occasions, are the essential components of a clients association with your program. The following is data on three occasions that let you catch a clients keystrokes in a Delphi application: OnKeyDown, OnKeyUp and OnKeyPress. Down, Up, Press, Down, Up, Press... Delphi applications can utilize two strategies for getting the contribution from the console. In the event that a client needs to type something in an application, the least demanding approach to get that info is to utilize one of the controls that consequently reacts to keypresses, for example, Edit. At different occasions and for increasingly broad purposes, in any case, we can make techniques in a structure that handle three occasions perceived by structures and by any part that acknowledges console input. We can compose occasion handlers for these occasions to react to any key or key mix the client may press at runtime. Here are those occasions: OnKeyDown - considered when any key on the console is pressedOnKeyUp - considered when any key on the console is releasedOnKeyPress - considered when a key comparing to an ASCII character is squeezed Console Handlers All the console occasions share one parameter for all intents and purpose. The Key parameter is the key on the console and is utilized to pass by reference of the estimation of the squeezed key. The Shift parameter (in the OnKeyDown and OnKeyUp systems) demonstrates whether the Shift, Alt, or Ctrl keys are joined with the keystroke. The Sender parameter references the control that was utilized to call the strategy. methodology TForm1.FormKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState) ; ... strategy TForm1.FormKeyUp(Sender: TObject; var Key: Word; Shift: TShiftState) ; ... methodology TForm1.FormKeyPress(Sender: TObject; var Key: Char) ; Reacting when the client squeezes alternate way or quickening agent keys, for example, those furnished with menu orders, doesn't require composing occasion handlers. What Is Focus? Center is the capacity to get client contribution through the mouse or console. Just the article that has the center can get a console occasion. Likewise, just a single part for every structure can be dynamic, or have the center, in a running application at some random time. A few segments, for example, TImage, TPaintBox, TPanel and TLabel can't get center. All in all, parts got from TGraphicControl can't get center. Also, parts that are imperceptible at run time (TTimer) can't get center. OnKeyDown, OnKeyUp The OnKeyDown and OnKeyUp occasions give the most reduced degree of console reaction. Both OnKeyDown and OnKeyUp handlers can react to all console keys, including capacity keys and keys joined with the Shift, Alt, and Ctrl keys. The console occasions are not fundamentally unrelated. At the point when the client presses a key, both the OnKeyDown and OnKeyPress occasions are produced, and when the client discharges the key, theà OnKeyUp occasion is created. At the point when the client squeezes one of the keys that OnKeyPress doesn't distinguish, just theà OnKeyDown occasion happens, trailed by theà OnKeyUp occasion. On the off chance that you hold down a key, the OnKeyUp occasion happens after all the OnKeyDown and OnKeyPress occasions have happened. OnKeyPress OnKeyPress restores an alternate ASCII character for g and G, yet OnKeyDown and OnKeyUp don't make a differentiation among capitalized and lowercase alpha keys. Key and Shift Parameters Since the Key parameter is passed by reference, the occasion handler can change Key with the goal that the application considers a to be key as being associated with the occasion. This is an approach to constrain the sorts of characters that the client can include, as to keep clients from composing alpha keys. on the off chance that Key in [A..Z], at that point Key : #0 The above explanation checks whether the Key parameter is in the association of two sets: lowercase characters (for example aâ through z) and capitalized characters (A-Z). Assuming this is the case, the announcement appoints the character estimation of zero to Key to forestall any contribution to the Edit part, for instance, when it gets the adjusted key. For non-alphanumeric keys, WinAPI virtual key codes can be utilized to decide the key squeezed. Windows characterizes uncommon constants for each key the client can press. For instance, VK_RIGHT is the virtual key code for the Right Arrow key. To get the key condition of some uncommon keys like TAB or PageUp, we can utilize the GetKeyState Windows API call. The key status determines whether the key is up, down, or flipped (on or off - rotating each time the key is squeezed). in the event that HiWord(GetKeyState(vk_PageUp)) 0 at that point ShowMessage(PageUp - DOWN) else ShowMessage(PageUp - UP) ; In the OnKeyDown and OnKeyUp occasions, Key is an unsigned Word esteem that speaks to a Windows virtual key. So as to get the character an incentive from Key,â we utilize the Chr work. In the OnKeyPress occasion, Key is a Char esteem that speaks to an ASCII character. Both OnKeyDown and OnKeyUp occasions utilize the Shift parameter, of type TShiftState, a set banners to decide the condition of the Alt, Ctrl, and Shift keys when a key is squeezed. For instance, when you press Ctrl A, the accompanying key occasions are created: KeyDown (Ctrl)/ssCtrl KeyDown (CtrlA)/ssCtrl A KeyPress (A) KeyUp (CtrlA) Diverting Keyboard Events to The Form To trap keystrokes at the structure level as opposed to passing them to the structures parts, set the structures KeyPreview property to True (utilizing the Object Inspector). The segment despite everything sees the occasion, yet the structure has a chance to deal with it first - to permit or deny a few keys to be squeezed, for instance. Assume you have a few Edit parts on a structure and the Form.OnKeyPress method resembles: technique TForm1.FormKeyPress(Sender: TObject; var Key: Char) ; start in the event that Key in [0..9], at that point Key : #0 end; In the event that one of the Edit parts has the Focus,â and theà KeyPreview property of a structure is False, this code won't execute. At the end of the day, if the client presses the 5 key, the 5 character will show up in the engaged Edit segment. Be that as it may, if the KeyPreview is set to True, thenâ the structures OnKeyPress occasion is executed before the Edit segment sees the key that is squeezed. Once more, on the off chance that the client has squeezed the 5 key, at that point it doles out the character estimation of zero to Key to forestall numerical contribution to the Edit segment.
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.