Pentaho Data Integration 界面开发-阿里云开发者社区

开发者社区> 开发与运维> 正文
登录阅读全文

Pentaho Data Integration 界面开发

简介:

1,简介

PDI界面使用了xul技术。通过配置xul文件就可以修改界面了。其次,具体图形界面的开发也用到了eclipse swt 和 Jface包。本文记录如何修改PDI的主界面的菜单栏,并新添加的菜单栏上做一些操作。

2,PDI中的xul配置

主要的配置文件有两个spoon.xul 和 menubar.xul。它们在项目主目录的 ui 目录下。spoon.xul 中定义了主界面的菜单栏、工具栏,同时也引用了 menubar.xul

<pen:include src="menubar.xul" ignoreroot="true"/>

munubar.xul 用来定义主界面的菜单。修改menubar.xul就可以修改菜单栏了。

 此外,启动界面的修改主要在这里:

Splash splash = new Splash(display);

 

3,具体操作步骤

根据menubar.xul中已有的格式新增一个菜单栏:

<menuitem id="submit-to-storm" label="${Spoon.Menu.File.SubmitToStorm}" command="spoon.submitToStorm()" />

其中, id 将会在PDI的main 类 Spoon.java 中相关语句用到。id 用来定位此菜单栏。 label 表示在该菜单栏上显示的内容,为了国际化,使用了一个单独的message文件来保存内容,在

src\org\troy\di\ui\spoon\messages 目录下的 zh 文件中新增该菜单显示的内容即可。效果图如下:

 

再分析下PDI是如何解析xul文件的:

复制代码
1 mainSpoonContainer = xulLoader.loadXul(XUL_FILE_MAIN, new XulSpoonResourceBundle());//XUL_FILE_MAIN=spoon.xul
2 
3  mainSpoonContainer.addEventHandler(this);//add listener
4 
5 mainSpoonContainer.getDocumentRoot().getElementById("spoon-menubar");//add menubar
6 
7  mainToolbar = (XulToolbar) mainSpoonContainer.getDocumentRoot().getElementById("main-toolbar");//add toolbar
复制代码

 

增加了menu之后,那么点击该menu之后,如何响应呢?这是由menubar.xul中的 “command” 来定义。它指定了当点击menu时,在Spoon类中需要执行的方法。比如,可以在点击menu之后,弹出一个文件选择对话框,只需要在"command"指定的方法里面生成一个FileDialog即可。

String[] filterExtensions = {"*.ktr", "*.kjb"};//设置过滤文件
FileDialog dialog = new FileDialog(shell, SWT.OPEN);//生成一个文件对话框
dialog.setFilterExtensions(filterExtensions);
String fname = dialog.open();//fname 获得在文件对话框中选择了哪个文件的路径

这样,使用 fname 就可以对该文件进行进一步操作了。

 

4,PDI界面编程

PDI中的各种对话框、选择框……主要是用 eclipse swt 和 jface 包中的类来实现的。对于 eclipse swt 编程需要import 以下的包:

import org.eclipse.swt.*;
import org.eclipse.swt.widgets.*;

然后需要 Display对象和 Shell 对象持有 swt 中的各种组件。然后就可以往 shell 中添加各种组件了。

Display display = new Display(); 
Shell shell = new Shell(display);

 

5,PDI中的文件操作

PDI借助 Java IO包和 org.apache.commons.vfs 包 实现KettleVFS.java ,通过KettleVFS类来实现文件系统的各种操作。比如实现文件复制:

复制代码
 1         BufferedInputStream fis = null;
 2         BufferedOutputStream fos = null;
 3 
 4         try {
 5 
 6             fis = new BufferedInputStream(KettleVFS.getInputStream(in));
 7             fos = new BufferedOutputStream(KettleVFS.getOutputStream(out, false));
 8 
 9             byte[] buf = new byte[1024 * 1024]; // copy in chunks of 1 MB
10             int i = 0;
11             while ((i = fis.read(buf)) != -1) {
12                 fos.write(buf, 0, i);
13             }
14             fos.flush();
15             fos.close();
16             fis.close();
复制代码

 

5,参考资料

swt 编程参考文档


本文转自hapjin博客园博客,原文链接:http://www.cnblogs.com/hapjin/,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章
最新文章
相关文章