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

From STX Wiki
Jump to navigationJump to search
(initial import)
 
No edit summary
 
(18 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{DISPLAYTITLE:{{SUBPAGENAME}}}}
{{DISPLAYTITLE:{{SUBPAGENAME}}}}
==KEY message parameters==
{{PG_GeneralDescriptions}}
 
When a key is pressed in a [[Programmer_Guide/Shell_Items/Dialog/DISPLAY_and_DIALOG_Messages#Dialog_.2F_Display|dialog]], [[Programmer_Guide/Shell_Items/Graph/GRAPH_Messages#KEY|graph]] or [[Programmer_Guide/Shell_Items/Display/DISPLAY_and_DIALOG_Messages#Keyboard_events|display]], a <code>KEY</code> 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. The [[Programmer_Guide/Shell_Items/Dialog/DISPLAY_and_DIALOG_Messages#Dialog_.2F_Display|DISPLAY]], [[Programmer_Guide/Shell_Items/Dialog/DISPLAY_and_DIALOG_Messages#Dialog_.2F_Display|DIALOG]] and the [[Programmer_Guide/Shell_Items/Graph/GRAPH_Messages#KEY|GRAPH]] items send KEY messages.
When a key is pressed in a dialog, graph or display, a <code>KEY</code> 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.


Please note that the <code>KEY</code> message parameter is case sensitive.
Please note that the <code>KEY</code> message parameter is case sensitive.


Alpha characters
==Alphanumerical Keys==


e.g. for the character 'a'


{|
{|
|-
|-
|key
!key
|control
!control+key
|shift
!shift+key
|message
!control+shift+key
|notes
!description
|-
|-
|a
|a
|no
|Ca
|no
|A
|'a'
|CA
|
|Note that shift plus an alpha character sends it in upper case. This is the same for all alpha characters.
|-
|a
|yes
|no
|'Ca'
|  
|-
|a
|no
|yes
|'A'
|  
|-
|a
|yes
|yes
|'CA'
|  
|}
 
Numerical characters
 
e.g. for the number '1'
 
{|
|-
|key
|control
|shift
|message
|notes
|-
|1
|no
|no
|'1'
|
|-
|-
|1
|1
|yes
|C1
|no
|'C1'
|
|-
|1
|1
|no
|C1
|yes
|The shift key has no effect on a number. This is the same for all numbers.
|'1'
|same as without shift
|-
|1
|yes
|yes
|'C1'
|same as without shift
|}
 
 
 
key
 
{|
|-
|
|
|
|
|
|-
|keyname
| key <nowiki>-</nowiki> description and comment
|-
| normal
|+control
|+shift
|+controlshift
|-
|<code>ch</code>lowercase
|<code>Cch</code>lower
|<code>ch</code>upper
|<code>Cch</code>upper
|ch is any character key (a – z); e.g.: [control][c] <nowiki>-</nowiki>> 'Cc', [shift][s] -> 'S', [a] -> 'a'
|-
|num
|Cnum
|snum
|*
|num is a numeric key and snum the corresponding symbol if pressed with shift (depends on keyboard layout); e.g. [8] <nowiki>-</nowiki>> '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. [+] <nowiki>-</nowiki>> '+', [shift][-] -> '_'
|}
|}


==Special Keys==




{|
{|
|-
|-
|
!key
|
!control+key
|
!shift+key
|
!control+shift+key
|
!description
|-
|keyname
| key <nowiki>-</nowiki> description and comment
|-
| normal
|+control
|+shift
|+controlshift
|-
|-
|Fn
|Fn
Line 144: Line 47:
|-
|-
|left
|left
|prefix C<nowiki>|</nowiki>S|CS
|Cleft
|cursor left [<<nowiki>-</nowiki>]
|Sleft
|CSleft
|The left arrow button
|-
|-
|right
|right
|prefix C<nowiki>|</nowiki>S|CS
|Cright
|cursor right [[Right Arrow]]
|Sright
|CSright
|The right arrow key
|-
|-
|up
|up
|prefix C<nowiki>|</nowiki>S|CS
|Cup
|cursor up [[Up Arrow]]
|Sup
|CSup
|The up arrow key
|-
|-
|down
|down
|prefix C<nowiki>|</nowiki>S|CS
|Cdown
|cursor down [[Down Arrow]]
|Sdown
|CSdown
|The down arrow key
|-
|-
|previous
|previous
|prefix C<nowiki>|</nowiki>S|CS
|Cprevious
|page up [PgUp]
|Sprevious
|CSprevious
|The page up key [PgUp]
|-
|-
|next
|next
|prefix C<nowiki>|</nowiki>S|CS
|Cnext
|page down [PgDn]
|Snext
|CSnext
|The page down key [PgDn]
|-
|-
|home
|home
|prefix C<nowiki>|</nowiki>S|CS
|Chome
|cursor home [Home]
|Shome
|CShome
|The home key
|-
|-
|end
|end
|prefix C<nowiki>|</nowiki>S|CS
|Cend
|cursor end [End]
|Send
|CSend
|The end key
|-
|-
|insert
|insert
|prefix C<nowiki>|</nowiki>S|CS
|Cinsert
|insert [INS]
|Sinsert
|CSinsert
|The insert key
|-
|-
|delete
|delete
|prefix C<nowiki>|</nowiki>S|CS
|Cdelete
|delete [DEL]
|Sdelete
|CSdelete
|The delete key [DEL]
|-
|-
|space
|space
|prefix C<nowiki>|</nowiki>S|CS
|Cspace
|space bar (blank) [ ]
|Sspace
|CSspace
|The space bar (blank
|-
|-
|add
|add
|prefix C<nowiki>|</nowiki>S|CS
|Cadd
|numeric pad add [+]
|Sadd
|CSadd
|The numeric pad add [<nowiki>+</nowiki>]
|-
|-
|subtract
|subtract
|prefix C<nowiki>|</nowiki>S|CS
|Csubtract
|numeric pad subtract [<nowiki>-</nowiki>]
|Ssubtract
|CSsubtract
|The numeric pad subtract [<nowiki>-</nowiki>]
|-
|-
|multiply
|multiply
|prefix C<nowiki>|</nowiki>S|CS
|Cmultiply
|numeric pad multiply [*]
|Smultiply
|CSmultiply
|The numeric pad multiply [<nowiki>*</nowiki>]
|-
|-
|divide
|divide
|prefix C<nowiki>|</nowiki>S|CS
|Cdivide
|numeric pad divide [/]
|Sdivide
|CSdivide
|Thenumeric pad divide [<nowiki>/</nowiki>]
|-
|-
|enter
|enter
|prefix C<nowiki>|</nowiki>S|CS
|Center
|enter / return [[RETURN]]
|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 <code>itemtype itemname CANCEL</code>.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 <var>keyname</var> is set to '<code>*</code>'. For the special keys (replaced with name strings) not all [control] and/or [shift] states are defined.
Notes: The key [ESC] (Escape) is never sent as a key message. It is always translated into the message <code>itemtype itemname CANCEL</code>.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 <var>keyname</var> is set to '<code>*</code>'. 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.

Latest revision as of 08:17, 15 March 2018

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. The DISPLAY, DIALOG and the GRAPH items send KEY messages.

Please note that the KEY message parameter is case sensitive.

Alphanumerical Keys

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.

Special Keys

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