Java:在RCP中实现用托拽打开Editor

工作台窗口的Editor区域默认是显示的,而且它支持拖拽操作。在Eclipse里面,把一个文件拖到Editor区域,就会自动打开该文件的 Editor.该特性是在IWorkbenchWindowConfigurer 中设置。       在PassWord Gate中,当拖动Password Gate View中的一个Group 或者 Service到Editor区域,会在Editor显示该项的属性。       要实现此特性,有四部分是必须的。       1     实现必要的Transfer类型,而且定义Editor要支持哪些类型。在Password Gate中,Transfer是LocalSelectionTransfer.Transfer用来进行数据的序列化,它可以支持在同一个程序,或不同 程序间拖拽。       2        因为在拖拽传递的过程中Editor Input 要实现序列化,所以要实现IPersistableElement接口。       3        加入一个释放适配器,当一个元素被扔到Editor区域,它可以知道如何进行操作,其实就是打开该元素的Editor.       4        使Password View能够进行拖操作,它要提供供拖的元素。       下面进行代码实现。       在RCP的WorkbenchWindowAdvisor. preWindowOpen中定义要求Editor Area支持的拖入对象的类型,以及打开相应Editor的事件。       ApplicationWorkbenchWindowAdvisor.preWindowOpen() 01 public void preWindowOpen() {
02     ......
03     configurer.addEditorAreaTransfer(LocalSelectionTransfer.getInstance());
04     configurer.configureEditorAreaDropListener(new EditorAreaDropAdapter(
05         configurer.getWindow())); 
06     }

    Row 03定义了Editor Area支持的Transfer为LocalSelectionTransfer, LocalSelectionTransfer为自己实现的传输介质类。Row 04定义了对拖入Editor Area的对象的处理方法。EditorAreaDropAdapter实现了DropTargetListener接口,用来监听Editor Area中的Drop事件,它会打开拖入Editor Area的对象所对应的Editor,假如同时拖入多个对象,它会打开每个对象对应的Editor.
  EditorAreaDropAdapter.java
01 public class EditorAreaDropAdapter extends DropTargetAdapter {
02   private IWorkbenchWindow window;
03   
04   public EditorAreaDropAdapter(IWorkbenchWindow window) {
05     this.window = window;
06   }
07 
08   public void dragEnter(DropTargetEvent event) {
09     // always indicate a copy
10     event.detail = DND.DROP_COPY;
11   }
12 
13   public void dragOperationChanged(DropTargetEvent event) {
14     // always indicate a copy
15     event.detail = DND.DROP_COPY;
public void drop(final DropTargetEvent event) {
19     Display d = window.getShell().getDisplay();
20     final IWorkbenchPage page = window.getActivePage();
21     if (page != null) {
22       d.asyncExec(new Runnable() {
23         public void run() {
24           asyncDrop(event, page);
25         }
26       });
27     }
28   }
29 
30   private void asyncDrop(DropTargetEvent event, IWorkbenchPage page) {
31     if (LocalSelectionTransfer.getInstance().isSupportedType(
32         event.currentDataType)) {
33       StrUCturedSelection selection = (StructuredSelection) event.data;
34       for (Iterator iter = selection.iterator(); iter.hasNext();) {
35         Object o = iter.next();
36         if (o instanceof Record) {
37           IEditorInput input = new RecordEditorInput((Record) o);
38           try {
39             page.openEditor(input, RecordEditor.ID);
40           } catch (Exception e) {
41             PwdgatePlugin.log("open ediotr RecordEditor", e);
42           }
43         } else if (o instanceof Group) {
44           IEditorInput input = new GroupEditorInput((Group) o);
45           try {
46             page.openEditor(input, GroupEditor.ID);
47           } catch (PartInitException e) {
48             PwdgatePlugin.log("open ediotr GroupEditor", e);
49           }
50         }
51       }
52     }
53   }
54 }
框架特点: 1.完善的企业应用解决方案,包括表现层,业务逻辑层,报表,权限,日志,国际化,部署等企业应用的各个环节。 2.B/S,C/S优势互补,随需应变。 3.全新的模式开发C/S客户端,无需布局,无需调整控件和组件的大小,不懂Swing也可以快速开发界面。 4.Spring+Hibernate的轻量级架构轻松开发业务逻辑。 5.提升用户体验,提高最终用户满意度,快速开发企业应用。 配置开发环境 1导入开发项目 下载(http://www.soyframework.com)已经配置好的空项目,此空项目包括empty-client (以下简称示例client项目)、empty-server (以下简称示例server项目),并将它们导入到Eclipse。如果Eclipse的Problems标签下没有出现错误那么表示项目成功导入。 如果使用其他的集成开发环境,请将client和server分别配置成java项目,且client依赖server。 2.1.2创建数据库 用户需要在自己的数据库管理系统创建一个数据库,并确保此数据库实例能正常运行。示例项目使用的数据库为MYSQL,假定我们在MYSQL创建数据库empty,并且创建用户empty,将数据库empty的所有权限授予给用户empty。 2.1.3配置hibernate 打开server项目下的hibernate.properties 文件,修改Hibernate数据库方言的配置(hibernate.dialect)为项目选用的数据库类型,如果采用是mysql 5.0数据库,设置为org.hibernate.dialect.MySQLDialect, 如果采用oracle9+数据库则设置为org.hibernate.dialect.Oracle9Dialect,如果是其他数据库请参考hibernate数据库方言。示例项目使用Mysql,故配置方言为org.hibernate.dialect.MySQLDialect。 打开server项目下的dataSourceConfig.xml文件,根据具体使用的数据库配置数据库连接池,下面列出了选用的数据库为Mysql时,连接池的配置: <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName"> <value>com.mysql.jdbc.Driver</value> </property> <property name="url"> <value>jdbc:mysql://${database.host}:${database.port}/empty?autoReconnect=true&useUnicode=true&characterEncoding=utf-8</value> </property> <property name="username"> <value>empty</value> </property> <property name="password"> <value>empty</value> </property> </bean> 在dataSourceConfig.properties配置数据库服务器的主机地址和端口: database.host=localhost database.port=3306 2.1.4运行项目 开发时使用的应用服务器为Jetty,Server项目下的JettyLauncher.java已经配置了一个Jetty服务器,应用名默认为empty,端口使用8888(用户可以根据实际情况自行修改)。将JettyLauncher作为java application运行,启动服务器,如不出现异常,则server项目配置成功。 打开client项目下的ApplicationLauncher.java文件,作为java application 运行,启动客户端。如果出现设置管理员界面,则client项目配置成功。设置管理员后在用户登录界面以管理员身份登录后即出现系统主界面。 转http://hi.csdn.net/mysoy
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值