`

深入Workbench框架

 
阅读更多
深入Workbench框架(结合UIPersistent)
1.整体架构E-R图

工作台(Workbench)包含一个或多个WorkbenchWindow,每个WorkbenchWindow又包含0~n个WorkbenchPage,不过一般情况下就一个WorkbenchPage页面。
WorkbenchPage中包含了Editor、View、Perspective等信息,其中Editor和View是在界面上用户可见的,透视图Perspective虽然可以通过透视图Bar进行切换,但它并不是UI组件,它只是View和Editor的集合,其中有Layout布局管理器可以控制View和Editor在Page也中的呈现。
我们要实现一个View或Editor,首先是要扩展org.eclipse.ui.views或org.eclipse.ui.editors扩展点,然后需要指定一个实现了ViewPart或EditorPart的实现类通重写createPartControl这个方法实现自定义的View或Editor的界面。
然而,在WorkbenchPage中为了有效利用系统资源是通过懒加载的形式加载ViewPart或EditorPart这些UI组件的。具体实现就是通过ViewFactory和EditorManger分别维护着Page中的View和Editor的引用,
称为ViewReference和EditorReference。只有当View和Editor需要显示时才通过这些Reference创建Part。
 
Part创建的时序图:

下面以创建一个view part的过程进行说明:
可以任意实现一个View,然后在createPartControl方法里打上行断点,debug模式启动该插件,可以通过Debug视图的状态栈信息,追踪View的整个创建过程:
把viewID传给当前的WorkbenchPage
IWorkbenchPage page = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getActivePage();
page.showView(id);
然后调用busyShowView方法,源码如下:
 protected IViewPart busyShowView(String viewID, String secondaryID, int mode)
            throws PartInitException {
        Perspective persp = getActivePerspective();//先得到当前的透视图
        //首先,会通过透视图查找是否存在对应id的Reference
        IViewReference ref = persp.findView(viewID, secondaryID);
        IViewPart view = null;
        if (ref != null) {
			view = ref.getView(true);//很关键,下面会说
		}
        if (view != null) {
            busyShowView(view, mode);
            return view;
        }

        // 如果没有view的reference,就通过透视图的showView方法,下文会继续说
        view = persp.showView(viewID, secondaryID);
        if (view != null) {
            busyShowView(view, mode);
          .....
        }
        return view;
  }
  其实Perspective的showView操作就两步:
  1.通过ViewFactory创建ViewReference;2.调用ref.getPart方法创建View
 
* Shows the view with the given id and secondary id.
     */
    public IViewPart showView(String viewId, String secondaryId)
            throws PartInitException {
        ViewFactory factory = getViewFactory();
        IViewReference ref = factory.createView(viewId, secondaryId);
          IViewPart part = (IViewPart) ref.getPart(true);
    ... ..
  }
  既然创建View的实际动作是通过ViewReference.getPart()方法完成的,下面看一下其具体实现:
  getPart方法是ViewReference的抽象父类WorkbenchPartReference的方法,采用了模板方法的模式调用了抽象方法  protected abstract IWorkbenchPart createPart(),而这个方法在ViewReference中实现。最终在createPartHelper方法中调用到了cratePart方法,创建了ViewPart:
private IWorkbenchPart createPartHelper() throws PartInitException {
		IWorkbenchPart result = null;
		IMemento stateMem = null;
		if (memento != null) {//获取View状态的持久化信息
			stateMem = memento.getChild(IWorkbenchConstants.TAG_VIEW_STATE);
		}
		IViewDescriptor desc = factory.viewReg.find(getId());
		// Create the part pane
		PartPane pane = getPane();//pane,就是表示一个窗口,负责View的窗体展现
		// Create the pane's top-level control
		pane.createControl(factory.page.getClientComposite());
		......
		try {
			IViewPart view = null;
			try {
				UIStats.start(UIStats.CREATE_PART, label);
				view = desc.createView();//创建ViewPart
			} finally {
				UIStats.end(UIStats.CREATE_PART, view, label);
			}

			if (view instanceof IWorkbenchPart3) {
				createPartProperties((IWorkbenchPart3)view);
			}
			// Create site
			site = new ViewSite(this, view, factory.page, desc);
			actionBars = new ViewActionBars(factory.page.getActionBars(), site,
					(ViewPane) pane);
			site.setActionBars(actionBars);
               .....
			int style = SWT.NONE;
			// Create the top-level composite
			{
				Composite parent = (Composite) pane.getControl();
				ViewDescriptor descriptor = (ViewDescriptor) 
                                   this.factory.viewReg.find(getId());
				if (descriptor != null && descriptor.getPluginId() != null) {
					parent.setData(new ContributionInfo(descriptor.getPluginId(),
							ContributionInfoMessages.ContributionInfo_View, null));
				}
				content = new Composite(parent, style);
				content.setLayout(new FillLayout());
				try {
					UIStats.start(UIStats.CREATE_PART_CONTROL, label);
					view.createPartControl(content);//调用重写的方法,完成view内容的填充
					parent.layout(true);
				} finally {
					UIStats.end(UIStats.CREATE_PART_CONTROL, view, label);
				}
			}
这里还要说明的是ViewFactory中维护了一个ViewReference的集合ReferenceCounter,其内部是一个“ViewID:引用次数对象”为键值对的HashMap,调用createView时会先从counter中获取该view所对应的Reference信息,如果不为空就调用addRef把引用次数加1,否则会创建一个新的reference并添加到counter中。
IViewReference ref = (IViewReference) counter.get(key);
        if (ref == null) {
            IMemento memento = (IMemento) mementoTable.get(key);
            ref = new ViewReference(this, id, secondaryId, memento);
            mementoTable.remove(key);
            counter.put(key, ref);
            getWorkbenchPage().partAdded((ViewReference)ref);
        } else {
            counter.addRef(key);
        }
每个View的reference的次数可以是0~n次,当为0时会通知下一次releaseview时把ViewPart从page中移除。
 public void releaseView(IViewReference viewRef) {
        String key = getKey(viewRef);
        IViewReference ref = (IViewReference) counter.get(key);
        if (ref == null) {
			return;
		}
        int count = counter.removeRef(key);
        if (count <= 0) {
            getWorkbenchPage().partRemoved((ViewReference)ref);
        }
  }
  2.看一下Reference和Part的内部E-R图示
  
  其中PartSite抽象类的子类有:EditorSite和ViewSite
  重其构造参数中就能大概猜出PartSite类的主要作用是什么了吧:
public PartSite(IWorkbenchPartReference ref, IWorkbenchPart part,IWorkbenchPage page) 
一个Site的主要任务就是管理part的内容(包括part本身,part的pane,contributions,selection provider等),实现了客户代码和reference、消息服务(Message serverse)之间的通信。
一个reference中包含了part的具体实现(ViewPart,EditorPart等)。
PartPane实现了LayoutPart控制part在Workbench中的布局。
WorkbenchPartReferences 使得SWT resources的懒加载成为了可能
private void disposePart(WorkbenchPartReference ref) {
        if (isDeferred()) {//ref被引用的次数是否大于0
            pendingDisposals.add(ref);//如果在被引用,就先放到一个临时性集合中不进行dispose
        } else {
       //如果没有引用了,则进行ref.dispose操作,会dispose掉它所持有的全部资源(part,pane等)
            partList.removePart(ref);
            ref.dispose();
        }
    }

  IWorkbenchPartReference 的生命周期图示:

  3.Workbench Layout
  
  一个LayoutPart管理着一个矩形区域内的widgets集合,同时可以包含或排列其他的layout parts,控制着相关区域的拖放功能(如常见的Editor区域的拖动,分成同时可编辑的区域等)、提供缩放的功能等布局相关的控制功能。
其中的PartPane就是控制着views或editors在workbench中的呈现。
  
  4.Action Bars
    (在上一篇的Action中有提到,此篇不再介绍)  
  
  参考资料:
  http://www.eclipse.org/articles/Article-UI-Workbench/workbench.html#mozTocId917303
  
  • 大小: 8.9 KB
  • 大小: 7.3 KB
  • 大小: 6 KB
  • 大小: 27.9 KB
  • 大小: 13.5 KB
  • 大小: 21 KB
分享到:
评论

相关推荐

    Workbench_workbench_workbench代码_ansys界面_

    《深入理解Ansys Workbench与Qt界面编程》 在计算机辅助工程(CAE)领域,Ansys Workbench是一款广泛使用的多物理场仿真软件,它提供了一种集成化的工作环境,允许用户进行结构、流体、热力等多学科的分析。而这段名...

    Wind River Workbench 3.0

    作为一个开放的平台,Workbench 3.0能够与其他开发工具和框架无缝集成,如Eclipse插件,以满足不同开发需求。同时,它提供了丰富的API和SDK,方便用户进行自定义扩展。 8. **文档和社区支持** 风河公司提供了详尽...

    workbench 3.3 pdf

    根据给定的信息,我们可以深入探讨Wind River Workbench 3.3 PDF文档中涉及的关键知识点,主要包括Workbench开发工具介绍、第三方许可通知以及特定组件(如Apache Software Foundation的软件和DOM4J库)的相关细节。...

    ABAP WorkBenchABAP WorkBench

    在深入探讨ABAP WorkBench的知识点之前,我们需要理解ABAP作为SAP的基础编程语言,主要用于构建企业级业务应用程序。 1. **开发工具**: ABAP WorkBench包含一系列开发工具,如SE38(ABAP Editor)、SE80(Object ...

    卡耐基workbench以及安装说明

    此外,你可以编写测试用例,通过集成的单元测试框架来验证代码的功能正确性。 压缩包中的"workbench的使用.ppt"文件可能是详细的使用教程,包含了如何有效地使用卡耐基Workbench的各种功能,从创建新项目到进行高级...

    RCP基本框架分析 Workbench是工作台,通俗地说就是代表用户界面的UI元素

    Shell对象代表应用程序中的窗口框架,用于与用户进行交互。它处理窗口的各种行为,如移动、缩放等。Shell可以通过`new Shell(Display)`或`Display.getCurrent().getActiveShell()`创建或获取。每个窗口都对应一个...

    kie workbench使用视频教程(Drools,jBPM)

    而"kie-workbench-how-to"文档可能包含了更全面的操作指南,帮助你深入了解kie workbench的日常使用。 "jbpm workbench使用.docx"可能是关于jBPM工作台的详细说明,涵盖其界面、功能以及如何与Drools集成。"内存...

    Wind River Workbench Vxworks user guide

    10. **测试与性能分析**:Workbench还提供了性能分析工具和测试框架,用于性能优化和验证应用程序。这部分将涵盖测试用例的创建、执行以及结果分析。 通过学习《Wind River Workbench VxWorks用户指南》,开发者...

    基于workbench模拟破片

    ### 基于Workbench与AUTODYN的活性破片战斗部仿真操作指南...这一仿真流程不仅涵盖了模型建立、材料选择、网格划分等基础步骤,还深入介绍了高级设置方法,如接触算法、高斯点选择等,有助于提高仿真的准确性和可靠性。

    安世亚太workbench培训资料第二部分

    《安世亚太Workbench培训资料第二部分:深入探讨DS技术》 在IT行业中,Workbench是一种广泛使用的集成开发环境(IDE),尤其在嵌入式系统和软件工程领域。本资料集主要聚焦于“DS”(可能指的是数据服务或数据科学...

    Regex Workbench超好用的正则工具

    同时,Regex Workbench支持最新的.NET框架,这意味着它可以利用.NET平台提供的强大正则表达式引擎,包括各种高级特性和功能。 正则表达式的语法相当丰富,主要包括以下核心概念: 1. **字符集**:如`[abc]`表示...

    LabVIEW通用视觉框架

    在本文中,我们将深入探讨LabVIEW通用视觉框架的核心特性、功能以及实际应用。 首先,让我们了解一下LabVIEW。LabVIEW(Laboratory Virtual Instrument Engineering Workbench)是由美国国家仪器公司(National ...

    labview AMC多线程框架模板学习研究

    在“labview AMC多线程框架模板学习研究”这个主题中,我们将深入探讨LabVIEW如何利用AMC(Advanced Modular Control)框架来实现多线程编程,以及如何在LabVIEW 2017 32位环境中通过VIPM(VI Package Manager)进行...

    数据建模 “DATA MODELER'S WORKBENCH”

    本书提供了一套完整的框架,帮助读者从概念、逻辑到物理层面对数据进行深入理解,同时也强调了数据建模过程中的人文因素。无论是对于新手还是经验丰富的专业人士而言,《Data Modeler’s Workbench》都是一本...

    workbench.7z

    本话题主要围绕"旧版本CPU上安装TensorFlow"这一主题展开,我们将深入探讨如何在不支持最新硬件特性的CPU上安装和运行TensorFlow。 首先,TensorFlow的性能很大程度上取决于硬件,特别是GPU的支持。然而,并非所有...

    ACT Customization Guide for Workbench.pdf

    1. **ACT基础**:了解ACT的基本概念,包括其在Workbench框架中的位置,以及如何通过ACT来构建和管理自定义组件。 2. **自定义操作**:学习如何创建和编辑自定义操作,这些操作可以是新的计算步骤或数据处理方法,以...

    ANSYS仿真案例Workbench有限元计算实例结果源文件流体fluent模型_bicycle-frame-61.zip

    《ANSYS Workbench流体分析:自行车框架的FLUENT模型》 在现代工程领域,ANSYS Workbench作为一款强大的多物理场仿真软件,被广泛应用于各种复杂问题的建模和求解。在这个特定的案例中,我们关注的是一个与自行车...

    ANSYS仿真案例Workbench有限元计算实例结果源文件流体fluent模型_car-frame

    《ANSYS Workbench流体分析:汽车框架的FLUENT模型及有限元计算实例》 在机械工程领域,ANSYS Workbench是一款强大的多物理场仿真软件,它集成了结构、流体、热力学等多个领域的仿真工具,使得工程师可以对复杂系统...

    tapestry 实例(Workbench)

    9. **源码分析**:通过查看“Workbench”的源码,我们可以深入理解Tapestry框架如何将业务逻辑、UI逻辑和数据模型结合起来,形成一个完整的Web应用。 10. **资源管理**:Tapestry提供了资源服务,用于加载静态资源...

Global site tag (gtag.js) - Google Analytics