`

@Marked-SWT常用的事件监听器之【MouseListener】

    博客分类:
  • Java
 
阅读更多

1.鼠标MouseListener有三个方法:

mouseDown:摁下触发;

mouseUp:松开时;

mouseDoubleClick:双击时;

左中右键都可

2.属性:

button:int:左=1;中=2;右=3;

stateMask:同KeyListener;

x,y:摁下处坐标

 

package com.iteye.niewj.swt.chapter1;

import org.eclipse.swt.SWT;
import org.eclipse.swt.events.MouseEvent;
import org.eclipse.swt.events.MouseListener;
import org.eclipse.swt.layout.RowData;
import org.eclipse.swt.layout.RowLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.swt.widgets.Text;

public class MouseEventShow {

	/**
	 * @author niewj
	 * @since 2012-6-4 
	 */
	public static void main(String[] args) {
//		外shell
		Display display = Display.getDefault();
		final Shell shell = new Shell(display);
		shell.setBounds(20, 100, 450, 500);
		shell.setText("鼠标事件");
		
//		布局管理器
		RowLayout layout = new RowLayout();
		layout.spacing=30;
		layout.marginWidth=30;
		layout.marginHeight=40;
		layout.wrap=true;
		layout.type=SWT.VERTICAL;
		shell.setLayout(layout);
		
//		RowData控制组件大小和隐藏
		//*text
		RowData textData = new RowData();
//		true隐藏组件,所占空间被忽略,下(后)面上(前)移
		textData.exclude=false;
		textData.height=150;
		textData.width=300;
		
		//*button
		RowData btnData = new RowData();
		btnData.exclude=false;
		btnData.height=30;
		btnData.width=200;

		//1.上button
		final Button button = new Button(shell, SWT.NONE);
		button.setText("上面按钮");
		button.setLayoutData(btnData);
		//2.中文本
		final Text text = new Text(shell, SWT.NONE);
		text.setText("文本框框");
		text.setLayoutData(textData);
		//3.下button
		final Button button2 = new Button(shell, SWT.NONE);
		button2.setText("下面按钮");
		button2.setLayoutData(btnData);
		
		text.addMouseListener(new MouseListener() {
			@Override
			public void mouseUp(MouseEvent e) {
				String msg = "";
				switch (e.button) {
				case 1:
					msg = "左键";
					break;
				case 2:
					msg = "中键";
					break;
				case 3:
					msg = "右键";
					break;
				}
				text.setText("松开文本框;事件源为:"+msg);
			}
			@Override
			public void mouseDown(MouseEvent e) {
				String msg = "";
				switch (e.button) {
				case 1:
					msg = "左键";
					break;
				case 2:
					msg = "中键";
					break;
				case 3:
					msg = "右键";
					break;
				}
				text.setText("摁下文本框,源为:"+msg);
			}
			@Override
			public void mouseDoubleClick(MouseEvent e) {
				String msg = "";
				switch (e.button) {
				case 1:
					msg = "左键";
					break;
				case 2:
					msg = "中键";
					break;
				case 3:
					msg = "右键";
					break;
				}
				text.setText("双击文本框,事件源为:"+msg);
			}
		});
		
//		显示
		shell.open();
		while(!shell.isDisposed()){
			if(!display.readAndDispatch()){
				display.sleep();
			}
		}
		display.dispose();
	}

}



分享到:
评论

相关推荐

    markdown:功能齐全的markdown解析器和编译器,以TypeScript编写

    用TypeScript编写的功能齐全的markdown解析器和编译器。 这是marked的流行库的分支(从chjj / release-0.3.7,2017年12月1日合并合并请求#961)。 郎 目录 安装 npm install @ts-stack/markdown --save 用法 最少...

    marked-toc:已弃用

    npm i -g marked-toc --save 在任何降价文件中,添加<!-- toc -->要添加 TOC 的位置。 然后在命令行中,运行: toc [filename] 如果您将 toc 添加到README.md ,则无需添加[filename] ,只需运行toc 。 ...

    marked-linkify-it:使用linkify-it标记网址

    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"; //...

    marked-0.3.2-1.zip

    标题中的"marked-0.3.2-1.zip"表明这是一个软件库的压缩包,标记为"marked"的版本0.3.2的第一个修正版。Marked通常是一个文本解析库,用于将Markdown语法转换为HTML,它在开发文档、博客和网站中非常常见。Markdown...

    marked-forms:从markdown生成html表单标签和输入控件

    从v4.0.0版本开始,如果设置了opts.allowSpacesInLinks,则插件将仅修补标记的链接标记器,以允许在未opts.allowSpacesInLinks链接中opts.allowSpacesInLinks空格。 推荐的替代方法是使用尖括号[]() (请参阅...

    marked-to-md:标记渲染器将 Markdown 渲染为... Markdown

    标记渲染器将 Markdown 渲染为... Markdown 等等……什么? 由于是一个良好且快速的 Markdown 解析器,因此解析和更新 Markdown 文档可能很有用。 使用示例: :打开标准 Markdown 文档并为 remark.js 添加所需的...

    marked-0.2.10.zip

    totalshare2java.zip,一种提供基于常用的OAuth2的第三个网站登录功能的工具。一种提供基于常用的OAuth2的第三个网站登录功能的工具。

    marked-engine:Express兼容的Markdown渲染由标记提供支持

    marked-engine是兼容的模板引擎,用于呈现Markdown。 安装 $ npm install marked-engine 用法 将marked-engine注册marked-engine扩展名为“ .md”的文件的模板引擎。 app . engine ( 'md' , require ( 'marked-...

    hexo-renderer-marked-plus:hexo-renderer 标记了更独特的标题 ID

    《Hexo-renderer-marked-plus:打造独特标题ID的JavaScript渲染器》 Hexo-renderer-marked-plus是一款针对Hexo博客框架的插件,它的主要功能是为Markdown解析提供更加独特且可定制化的标题ID。这个插件是在hexo-...

    marked-terminal:标记项目的渲染器。 允许您渲染Markdown以打印到终端

    用于自定义渲染器,允许将Markdown打印到终端。 支持漂亮的表格,JavaScript的语法高亮显示以及覆盖所有颜色和样式。 例如,可用于打印使用情况信息。 安装 npm install marked marked-terminal 例子 var marked = ...

    一款使用marked和highlightjs开发的一款markdown编辑器

    Markdown编辑器是程序员和内容创作者常用的工具,它允许用户使用简单的文本格式编写文档,并能转换成HTML,方便在网页上展示。本项目是一款基于marked和highlight.js开发的Markdown编辑器,专为Vue项目设计。接下来...

    marked-images:简单的标记渲染器,可在markdown中包含图像属性。 还生成vimeo链接

    var marked = require ( 'marked' ) ;var markedImages = require ( 'marked-images' ) ;// opts are optionalvar opts = { xhtml : false , fqImages : { route : '/images/' , url : '...

    marked.min.js

    开发者可以使用marked库提供的默认渲染器进行转换,也可以通过继承marked的Renderer类来自定义渲染器,实现对特定HTML元素或属性的定制化渲染。 在使用`marked.min.js`时,需要注意的是,虽然它支持大多数常见的...

    marked-sanitizer-github:一个marked.js的净化器,它以与GitHub相同的方式净化markdown中HTML元素

    $ npm install --save marked-sanitizer-github 用法 它输出一类SanitizeState因为该清理是有状态的。 您可以通过调用getSanitizer()方法来为标记的解析器获取一个消毒剂。 它返回一个要清除的函数对象。 con

    marked-element:标记的库的元素接口

    描述中提到"标记元素仅与聚合物0.5及更低版本兼容,将不推荐使用",这表明marked-element最初是为 Polymer 0.5 设计的,随着Polymer框架的发展,尤其是从0.5版本升级到0.8及更高版本时,这个元素可能不再是最优选择...

    marked-preview:快速和最小的降价预览充满了Material Design。 :fountain_pen:

    提示:您可以使用设置菜单中提供的“清除编辑器”选项。如何利用源代码? 涉及的步骤如下:$ git clone https://github.com/code-plus-coffee/marked-preview.git$ cd marked-preview# NPM$ npm install or npm i# ...

    marked-calendar:点亮元素的webcomponent标记日历

    演示版<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"}, {...

Global site tag (gtag.js) - Google Analytics