深入浅出Eclipse RCP(1):Hello RCP

开发 后端
Eclipse RCP(Rich Client Platform)允许开发者使用Eclipse架构设计灵活的、可扩展的、美观的应用程序。本系列希望通过层层深入的介绍,一步一步带您进入Eclipse RCP的玄妙世界。
第一个RCP程序

打开Eclipse,新建一个Plug-in Project,点击Next。在Project name文本框中输入项目名称net.kirin.rcp.hello,如下图所示。

新建Plug-in Project

点击Next,如下图所示,在“Would you like to create a rich client application?”后面选中Yes。其余均可保留默认值。

保留默认值

点击Next,选择Hello RCP模板。

Hello RCP模板

点击Next,打开如下对话框,各项均可保留默认值。

保留默认值

点击Finish,将创建结构如下的项目。

点击Finish

双击MANIFEST.MF文件,将打开一个名为Overview的界面,点击Launch an Eclipse application,

Overview界面

结果如下图所示。

结果

这就是我们的第一个RCP程序。当然,我们没有写一行代码,完全是Hello RCP模板自动为我们创建的。

代码解析

可以看到,RCP模板自动为我们创建了Application.java、ApplicationActionBarAdvisor.java、ApplicationWorkbenchAdvisor.java、ApplicationWorkbenchWindowAdvisor.java、Perspective.java这5个类。下面我们对这5个类进行逐一分析。

Application类

在普通的Java程序中,总有一个main()方法作为应用程序的入口点。而RCP程序的入口点则是Application类。打开Application.java文件,可以看到该类实现了IPlatformRunnable接口,入口方法如下所示:

public Object run(Object args) throws Exception {
    Display display = PlatformUI.createDisplay();
    try {
        int returnCode = PlatformUI.createAndRunWorkbench(display, new ApplicationWorkbenchAdvisor());
        if (returnCode == PlatformUI.RETURN_RESTART) {
            return IPlatformRunnable.EXIT_RESTART;
        }
        return IPlatformRunnable.EXIT_OK;
    } finally {
        display.dispose();
    }
}

run()方法为IPlatformRunnable接口所定义的方法,在RCP程序启动时,会首先执行该方法。Application首先创建一个Display对象, 然后调用PlatformUI.createAndRunWorkbench()方法创建并启动工作台,这将打开应用程序主窗口,并使该窗口处于持续打开状态。应用程序开始处理用户的鼠标单击、鼠标移动、按键等各种事件,直到用户关闭程序退出,这就是所谓的事件循环。当然,在关闭之前,必须用display.dispose()销毁Display对象以释放资源。

ApplicationWorkbenchAdvisor类

在PlatformUI.createAndRunWorkbench()方法中,还传入了一个新建的ApplicationWorkbenchAdvisor对象。它类负责应用程序生命周期管理,它继承自WorkbenchAdvisor类。开发人员可以在该类中实现程序启动或者关闭时的某种处理。该类的具体实现只是给用户一个初始的视图界面而已,还需要配合WorkbenchWindowAdvisor、ActionBarAdvisor才能构成一个较为完整的用户界面。

打开ApplicationWorkbenchAdvisor.java文件,代码如下:

public class ApplicationWorkbenchAdvisor extends WorkbenchAdvisor {

    private static final String PERSPECTIVE_ID = "net.kirin.rcp.hello.perspective";

    public WorkbenchWindowAdvisor createWorkbenchWindowAdvisor(IWorkbenchWindowConfigurer configurer) {
        return new ApplicationWorkbenchWindowAdvisor(configurer);
    }

    public String getInitialWindowPerspectiveId() {
        return PERSPECTIVE_ID;
    }
}

createWorkbenchWindowAdvisor()方法初始化在主界面显示的透视图,并返回ApplicationWorkbenchWindowAdvisor对象。

ApplicationWorkbenchAdvisor还包含一些比较重要的方法:

  • initialize:最先调用。在窗口打开之前调用,可以用来处理初始化配置工作。
  • preStartup:initialize之后、第一个窗口打开之前调用,可以用来处理临时或者可选处理工作。
  • postStartup:第一个窗口打开之后但启动事件循环之前调用,可以用来进行那些需要自动处理的工作,例如弹出一个提示窗口。
  • preShutdown:事件循环结束之后但窗口关闭之前调用,可以用来进行保存数据、关闭数据库服务器等处理工作。
  • postShutdown:窗口关闭之后调用,可以用来进行保存应用程序状态、清除initialize创建的对象等处理工作。

ApplicationWorkbenchWindowAdvisor类

在ApplicationWorkbenchAdvisor类中创建了一个ApplicationWorkbenchWindowAdvisor对象。它主要负责窗口生命周期的管理,例如状态栏、工具栏、菜单、窗口标题、窗口大小和各种控件等等,也可以处理窗口的各种事件例程。其主要代码如下:

public class ApplicationWorkbenchWindowAdvisor extends WorkbenchWindowAdvisor {

    public ApplicationWorkbenchWindowAdvisor(IWorkbenchWindowConfigurer configurer) {
        super(configurer);
    }

    public ActionBarAdvisor createActionBarAdvisor(IActionBarConfigurer configurer) {
        return new ApplicationActionBarAdvisor(configurer);
    }
    
    public void preWindowOpen() {
        IWorkbenchWindowConfigurer configurer = getWindowConfigurer();
        configurer.setInitialSize(new Point(400, 300));
        configurer.setShowCoolBar(false);
        configurer.setShowStatusLine(false);
        configurer.setTitle("Hello RCP");
    }
}

preWindowOpen()方法在窗口控件创建之前调用,用来配置窗口,如设置窗口大小、工具栏、状态栏和标题等。createActionBarAdvisor创建了一个ApplicationActionBarAdvisor对象。

其它比较重要的方法还包括:

  • postWindowRestore:当窗口根据上一次的保存状态恢复创建之后调用,可以用来调整调整窗口恢复状态。
  • postWindowCreate:窗口创建之后调用,可以用于调整窗口。
  • postWindowOpen:窗口已经打开之后调用,可以用来注册窗口监听,例如在此方法中实现系统托盘。

ApplicationActionBarAdvisor类

ApplicationActionBarAdvisor主要负责管理窗口的菜单栏、状态栏、工具栏的外观和行为。其主要代码如下:

public class ApplicationActionBarAdvisor extends ActionBarAdvisor {

    public ApplicationActionBarAdvisor(IActionBarConfigurer configurer) {
        super(configurer);
    }

    protected void makeActions(IWorkbenchWindow window) {
    }

    protected void fillMenuBar(IMenuManager menuBar) {
    }
    
}

makeActions()方法用来注册菜单或工具栏的动作。fillMenuBar()方法用来添加菜单栏。

其它比较重要的方法还包括:

  • fillCoolBar:添加工具栏
  • fillStatusLine:添加状态栏

Perspective类

Perspective类主要负责界面布局的安排,其代码如下:

public class Perspective implements IPerspectiveFactory {

    public void createInitialLayout(IPageLayout layout) {
    }
}

createInitialLayout()方法通常用于创建初始的界面布局。

小结

本篇作为《深入浅出Eclipse RCP》系列的开篇,介绍了如何使用Hello RCP模板创建最简单的RCP程序,并对自动生成的5个类进行了解析。如果您是RCP的初学者,也许会对本文中出现的一些概念改到困惑。没有关系,我将在接下来的随笔中介绍RPC的基本架构以及Workbench、Action、Perspective等概念。

【编辑推荐】

  1. Eclipse自动补全增强
  2. Ubuntu安装Eclipse-SDK-3.3小结
  3. Eclipse乱码解决办法
  4. Windows下安装JDK Tomcat Eclipse配置详解
  5. 用SketchUp和Eclipse进行3-D建模(1)
责任编辑:book05 来源: cnblogs
相关推荐

2021-03-16 08:54:35

AQSAbstractQueJava

2011-07-04 10:39:57

Web

2012-02-07 14:37:01

Android核心组件Service

2017-07-02 18:04:53

块加密算法AES算法

2012-05-21 10:06:26

FrameworkCocoa

2019-01-07 15:29:07

HadoopYarn架构调度器

2021-07-20 15:20:02

FlatBuffers阿里云Java

2022-09-26 09:01:15

语言数据JavaScript

2009-05-20 14:48:07

ibmdwEclipse开发技巧

2009-06-15 16:23:39

Eclipse中使用SEclipse RCP

2021-04-27 08:54:43

ConcurrentH数据结构JDK8

2022-11-09 08:06:15

GreatSQLMGR模式

2022-12-02 09:13:28

SeataAT模式

2012-02-21 13:55:45

JavaScript

2018-11-09 16:24:25

物联网云计算云系统

2009-11-18 13:30:37

Oracle Sequ

2022-01-11 07:52:22

CSS 技巧代码重构

2009-11-30 16:46:29

学习Linux

2019-12-04 10:13:58

Kubernetes存储Docker

2019-11-11 14:51:19

Java数据结构Properties
点赞
收藏

51CTO技术栈公众号