Programmer Guide/General Descriptions/KEY message parameters: Difference between revisions

From STX Wiki
Jump to navigationJump to search
Line 4: Line 4:


Please note that the <code>KEY</code> message parameter is case sensitive.
Please note that the <code>KEY</code> message parameter is case sensitive.
===Numerical characters===
e.g. for the number '1'
{|
|-
!key
!control
!shift
!message
!notes
|-
|1
|no
|no
|'1'
|
|-
|1
|yes
|no
|'C1'
|
|-
|1
|no
|yes
|'1'
|same as without shift
|-
|1
|yes
|yes
|'C1'
|same as without shift
|}


===key===
===key===

Revision as of 08:55, 13 December 2017

When a key is pressed in a dialog, graph or display, a KEY message is sent to the controlling shell. The message parameter describes which key was pressed, and whether the control and/or shift keys were up or down at the time. A description of the parameter follows. Note that not all keys are sent. Only alphanumerical and some other special keys are sent.

Please note that the KEY message parameter is case sensitive.

key

key control+key shift+key control+shift+key description
a Ca A CA Note that shift plus an alpha character sends it in upper case. This is the same for all alpha characters.
1 C1 1 C1 The shift key has no effect on a number. This is the same for all numbers.
num Cnum snum * num is a numeric key and snum the corresponding symbol if pressed with shift (depends on keyboard layout); e.g. [8] -> '8', [shift][4] -> '$'
sym * ssym * sym is a symbol key and ssym the corresponding symbol if pressed with shift (depends on keyboard layout); e.g. [+] -> '+', [shift][-] -> '_'


key control+key shift+key control+shift+key description
Fn CFn SFn CSFn Function key[Fn]; with: n = 1 .. 12
left Cleft Sleft CSleft The left arrow button
right Cright Sright CSright The right arrow key
up Cup Sup CSup The up arrow key
down Cdown Sdown CSdown The down arrow key
previous Cprevious Sprevious CSprevious The page up key [PgUp]
next Cnext Snext CSnext The page down key [PgDn]
home Chome Shome CShome The home key
end Cend Send CSend The end key
insert Cinsert Sinsert CSinsert The insert key
delete Cdelete Sdelete CSdelete The delete key [DEL]
space Cspace Sspace CSspace The space bar (blank
add Cadd Sadd CSadd The numeric pad add [+]
subtract Csubtract Ssubtract CSsubtract The numeric pad subtract [-]
multiply Cmultiply Smultiply CSmultiply The numeric pad multiply [*]
divide Cdivide Sdivide CSdivide Thenumeric pad divide [/]
enter Center Senter CSenter The enter key [RETURN]

Notes: The key [ESC] (Escape) is never sent as a key message. It is always translated into the message itemtype itemname CANCEL.Not all [control][key] codes are defined in the ASCII character set and some are directly processed by the system. Therefore some combinations can not be translated and keyname is set to '*'. For the special keys (replaced with name strings) not all [control] and/or [shift] states are defined.

See the key_messages.sts example script to see this all in action.

Navigation menu

Personal tools