【插件开发】—— 13 GEF双击模型事件
时间:2022-04-22
本文章向大家介绍【插件开发】—— 13 GEF双击模型事件,主要内容包括第一种 performRequest、第二种,就是在Editor类中,对整个viewer添加双击事件监听、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
前文回顾: 1 插件学习篇 2 简单的建立插件工程以及模型文件分析 3 利用扩展点,开发透视图 4 SWT编程须知 5 SWT简单控件的使用与布局搭配 6 SWT复杂空间与布局搭配 7 SWT布局详解 8 IPreferenceStore使用详解 9 编辑器代码着色 10 JFace开发 11 GEF监听 12 GEF入门
由于GEF的架构过于庞大,对于新手来说确实不易。而对于GEF典型的应用场景,模型拖拽编辑,一个常用的操作方式就是双击模型弹出对话框进行编辑。但是由于模型是我们自己定义的,如何双击模型产生事件这个就点摸不着头脑了。
由于GEF的模型都是我们自定义的,因此根本不具有双击的方法。但是可以通过其他的渠道来达到目的。
下面介绍两种常见的双击模型,产生响应的方法:
第一种 performRequest
在模型对应的EditPart中添加performRequest方法,捕捉事件
public void performRequest(Request req) {
if(req.getType().equals(RequestConstants.REQ_OPEN)){
MessageDialog.openInformation(getViewer().getControl().getShell(),"Gef Practice","A Dialog");
}
}
这种方法时从八进制的博客中学习的。其中RequestConstants还有很多常量,可以多关注一下。
第二种,就是在Editor类中,对整个viewer添加双击事件监听
首先我们需要定义一个接口
1 public interface IDoubleClickSupport {
2
3 public void doubleClicked();
4
5 }
继承这个接口的模型,都需要实现一个doubleClicked方法。
然后,需要在Editor.java中添加监听事件
1 protected void initializeGraphicalViewer() {
2 viewer = getGraphicalViewer();
3 ....
4 viewer.getControl().addMouseListener(new MouseAdapter(){
5 public void mouseDoubleClick(MouseEvent e){
6 IStructuredSelection selection = (IStructuredSelection)getGraphicalViewer().getSelection();
7 Object obj = selection.getFirstElement();
8 if(obj!=null && obj instanceof IDoubleClickSupport){
9 ((IDoubleClickSupport)obj).doubleClicked();
10 }
11 }
12 });
13
14 }
这里通过调用getGraphicalViewer().getSelection()可以获得点击的对象,如果这个对象属于我们自己定义的接口,就会触发双击事件。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法