getkey

版本 2.1 (2.8 KB) 作者: Jos (10584)
Get a keypress
20.4K 次下载
更新时间 2019/2/11

查看许可证

编者注: This file was selected as MATLAB Central Pick of the Week

CH = getkey waits for a single keypress and returns the ASCII code. It
accepts all ascii characters, including backspace (8), space (32),
enter (13), etc, that can be typed on the keyboard.
Non-ascii keys (ctrl, alt, ..) return a NaN. CH is a double.

CH = getkey(N) waits for N keypresses and returns their ASCII codes.
getkey(1) is the same as getkey without arguments.

getkey('non-ascii') or getkey(N, 'non-ascii') uses non-documented
matlab features to return a string describing the key pressed.
In this way, keys like ctrl, alt, tab etc. can also distinguished.
The return is a string (when N = 1) or a cell array of strings.

[CH, T] = getkey(...) also returns the time between the start of the
function and each keypress. This is, however, not very accurate.

This function is kind of a workaround for "getch" in C. It uses a modal,
but non-visible window, which does show up in the taskbar.
C-language keywords: KBHIT, KEYPRESS, getkey, GETCH

Example 1 - get a single ascii key
fprintf('\nPress any key: ') ;
ch = getkey ;
fprintf('%c\n',ch) ;

Example 2 - wait for a specific key
fprintf('\nPress the Ctrl-key within 3 presses: ') ;
ch = getkey(3,'non-ascii')
if ismember('control', ch), fprintf('OK\n') ;
else fprintf(' ... wrong keys ...\n') ; end

Example 3 - Typing game
S = 'abcdefghjiklm' ;
fprintf('Type "%s" as fast as possible ...\n', S) ;
[C, T] = getkey(numel(S)) ;
C = char(C) ; T = T(end)-T(1) ;
if ~isequal(S, C), fprintf('OOPS!!! ') ; end
fprintf('You typed "%s" in %.2f seconds.\n', C, T) ;

See also input, uiwait
getkeywait (file Exchange)

Author's note: after 14 years still going strong ;-)

引用格式

Jos (10584) (2026). getkey (https://ww2.mathworks.cn/matlabcentral/fileexchange/7465-getkey), MATLAB Central File Exchange. 检索时间: .

MATLAB 版本兼容性
创建方式 R2018b
兼容任何版本
平台兼容性
Windows macOS Linux
类别
Help CenterMATLAB Answers 中查找有关 Argument Definitions 的更多信息
版本 已发布 发行说明
2.1

modernised & added typing game example

1.3.0.0

Update 2.0 (june 2012): ability to get multiple keypresses

1.2.0.0

changed some figure properties; added check of figure existence

1.1.0.0

tested for newer releases

1.0.0.0

updated lay-out