KeyListener也有两个事件方法:
1. KeyPressed 和 KeyReleased
KeyPressed:顾名思义,摁下键盘触发事件;
KeyReleased:松开摁键触发。
2.事件对象KeyEvent有三个属性比较有用:
character:得到按键对应的字符,类型为char,所以包括汉字等编码值。
keyCode: 得到按键码。如a在键盘的摁键码为97;
stateMask: 利用 & (位与)运算来判断是否某个键被摁下。多用来检测是否同时按下 Ctrl, Alt, Shift 键。
如:
package com.iteye.niewj.swt.chapter1; import org.eclipse.swt.SWT; import org.eclipse.swt.events.KeyEvent; import org.eclipse.swt.events.KeyListener; import org.eclipse.swt.widgets.Display; import org.eclipse.swt.widgets.Label; import org.eclipse.swt.widgets.Shell; import org.eclipse.swt.widgets.Text; public class KeyEventShow { /** * @author niewj * @since 2012-6-1 */ public static void main(String[] args) { Display display = new Display(); //1.一个窗口 final Shell shell = new Shell(display); shell.setText("键盘监听器"); shell.setBounds(60, 40, 300, 400); //2.一个按钮 Label label = new Label(shell, SWT.PUSH); label.setText("输入框"); label.setBounds(10, 50,100, 25); final Text text = new Text(shell, SWT.BORDER|SWT.PASSWORD); text.setBounds(120, 50, 150, 25); final Text result = new Text(shell, SWT.BORDER|SWT.MULTI|SWT.WRAP); result.setBounds(120, 80, 150, 125); /* 键盘监听器 */ text.addKeyListener(new KeyListener() { @Override public void keyReleased(KeyEvent e) { result.setText(text.getText()); } @Override public void keyPressed(KeyEvent e) { System.out.println("摁下键盘:"+e.character+" = "+e.keyCode); boolean flag1 = (e.stateMask & SWT.CTRL)!=0; //同时按下Ctrl+一个其他键就不为0 boolean flag2 = (e.stateMask & SWT.ALT)!=0; //同时按下Alt+一个其他键就不为0 System.err.println(flag1+";"+flag2); if(flag1 && flag2){ System.err.println("您同时按下了Ctrl+Alt+其他键"); } } }); //4.设置显示 shell.layout(); shell.open(); while(!shell.isDisposed()){ if(!display.readAndDispatch()){ display.sleep(); } } display.dispose(); } }
相关推荐
browsermob-proxy-client.zip,Java客户端库通过其rest-apiJava客户端库独家安装、启动和控制BrowserMob代理通过其rest-api独家安装、启动和控制BrowserMob代理
从v4.0.0版本开始,如果设置了opts.allowSpacesInLinks,则插件将仅修补标记的链接标记器,以允许在未opts.allowSpacesInLinks链接中opts.allowSpacesInLinks空格。 推荐的替代方法是使用尖括号[]() (请参阅...
const marked = require ( "marked" ) ; const linkify = require ( "marked-linkify-it" ) ; // or ES Module script // import marked from "https://cdn.jsdelivr.net/gh/markedjs/marked/lib/marked.esm.js"; //...
totalshare2java.zip,一种提供基于常用的OAuth2的第三个网站登录功能的工具。一种提供基于常用的OAuth2的第三个网站登录功能的工具。
marked-engine是兼容的模板引擎,用于呈现Markdown。 安装 $ npm install marked-engine 用法 将marked-engine注册marked-engine扩展名为“ .md”的文件的模板引擎。 app . engine ( 'md' , require ( 'marked-...
用TypeScript编写的功能齐全的markdown解析器和编译器。 这是marked的流行库的分支(从chjj / release-0.3.7,2017年12月1日合并合并请求#961)。 郎 目录 安装 npm install @ts-stack/markdown --save 用法 最少...
用于自定义渲染器,允许将Markdown打印到终端。 支持漂亮的表格,JavaScript的语法高亮显示以及覆盖所有颜色和样式。 例如,可用于打印使用情况信息。 安装 npm install marked marked-terminal 例子 var marked = ...
npm i -g marked-toc --save 在任何降价文件中,添加<!-- toc -->要添加 TOC 的位置。 然后在命令行中,运行: toc [filename] 如果您将 toc 添加到README.md ,则无需添加[filename] ,只需运行toc 。 ...
var marked = require ( 'marked' ) ;var markedImages = require ( 'marked-images' ) ;// opts are optionalvar opts = { xhtml : false , fqImages : { route : '/images/' , url : '...
hexo-renderer-marked-plus 极大地基于hexo-renderer-marked-plus ,只是在 CSS 样式冲突的情况下修改标题的 id。
提示:您可以使用设置菜单中提供的“清除编辑器”选项。如何利用源代码? 涉及的步骤如下:$ git clone https://github.com/code-plus-coffee/marked-preview.git$ cd marked-preview# NPM$ npm install or npm i# ...
演示版<h2>Basic marked-calendar Demo</h2><h3>Demo</h3><marked-calendar year="2020" title="Imputacion de horas" savedata weekends legend='[ {"code": "#0F0", "label": "V", "title": "Vacaciones"}, {...
标记渲染器将 Markdown 渲染为... Markdown 等等……什么? 由于是一个良好且快速的 Markdown 解析器,因此解析和更新 Markdown 文档可能很有用。 使用示例: :打开标准 Markdown 文档并为 remark.js 添加所需的...
$ npm install --save marked-sanitizer-github 用法 它输出一类SanitizeState因为该清理是有状态的。 您可以通过调用getSanitizer()方法来为标记的解析器获取一个消毒剂。 它返回一个要清除的函数对象。 con
十六进制渲染器标记 添加对支持。 此插件使用为其渲染引擎。安装$ npm install hexo-renderer-marked --save 十六进制4:> = 2.0 十六进制3:> = 0.2 十六进制2:0.1.x选项您可以在_config.yml配置此插件。 marked :...
marked, Markdown 解析器和编译器 为速度而生 标记一个全功能的Markdown 解析器和编译器,用。 为速度而生。 安装npm install marked --save用法最小用法:var marked = require('marked');con
用户宏,可通过marked.js在Confluence页面内允许GitHub风格的降价块。描述此宏旨在在页面中呈现markdown主体内容,同时在宏主体中保留原始markdown代码,以便页面的后续编辑可以更新markdown代码。 markdown代码在...