`

开发视图插件(转)

 
阅读更多

视图是工作台页面内的可视组件,通常用来浏览信息的层次结构(如工作空间)、打开编辑器或显示活动编辑器的属性。用户可以通过“Window”→“Show view”菜单显示视图,也可以从视图局部标题栏关闭视图。


视图分类


Eclipse中用户可以在同一时间打开多个视图(编辑器在同一时间只能打开一个),每个视图能够有自己的位置布局信息,Eclipse会根据上一次视图布局的信息初始化视图。
Eclipse视图一般来说有两种表现形式,一种是用户通过视图扩展点“org.eclipse.ui.views”实现自定义的视图,另一种是实现Eclipse中视图提供的扩展,用户可以通过实现Eclipse的相应接口实现,如Outline视图和Properties视图,如图1所示。


图1 Eclipse视图

在Eclipse中,用户可以按自己的要求建立自己的视图,即扩展Eclipse的视图扩展点。也能实现Eclipse的接口,通过Eclipse的Adapter机制实现Eclipse的扩展。其中,Outline和Properties视图也是通过这种方式实现的,在后面的章节会介绍Outline视图和Properties视图的实现。
当用户定义了自己的视图后能通过“Window”→“Show view”菜单打开自定义的视图。如图2所示。


图2 选择视图


常用视图可实现的功能


Eclipse的视图就功能来说一般有两种形式,一种是功能性视图,例如Java的Default视图,default负责用树形目录组织Java的项目结构,并且能通过双击节点在编辑器中打开相应的资源。另一种视图是辅助型的视图,例如Console负责控制台信息的显示。
不管是哪种类型的视图,它们的实现原理是一样的。在Eclipse中视图可以实现的功能有如下一些。
 右键菜单:可以通过视图中的树、表弹出的菜单完成相应的功能。
 工具栏:可以定制视图的工具栏,完成当前视图的功能。
 表格:视图中可以加入表格以显示相应的表结构信息。
 树:视图中可以加入树结构以显示相应的树结构信息。
 Log 输出:视图中可以直接输出信息。
这些只是一般在Eclipse中可以看到的实现,用户可以把视图当做操作Eclipse接口。
提示:任何SWT的组件都可以作为视图的一部分,用户可以按自己的需求定制自己的视图。


创建“Tree viewer”视图


创建“Tree viewer”视图插件项目,步骤如下:
1. 打开新建向导。
单击Eclipse的“File”→“New”→“Other”菜单项,在弹出的对话框中选择Select对话框左边的 Plug-in Development 向导。
2. 建立一个空的插件项目。
 输入插件工程的名字为“com.free.view. treeview”。
 输入插件的ID为“com.free.view.treeview”。
 输入插件的Name为“helloworld Plug-in”。
 选择使用模板建立插件项目,如图3所示。
 单击“Next”按钮,选择“Tree viewer”选项。
 单击“Finish”按钮,完成项目的建立。


图3 选择插件模板对话框


通过这种方式建立了一个包含JFace的“Tree viewer”组件的插件项目,此项目已经具备了视图插件常用的功能。


视图扩展点


通过插件模板创建了“Tree viewer”视图插件,此插件只实现了一个视图分类节点和视图节点。如例程1所示。
例程1 plugin.xml
<plugin>

<extension
point="org.eclipse.ui.views">
<category
name="tree view"
id="com.free.view.categoryall">
</category>
<view
name="Tree View"
icon="icons/tree.GIF"
category="com.free.view.categoryall"
class="com.free.view.treeview.views.TreeViewTest"
id="com.free.view.treeview.views.TreeViewTest">
</view>
</extension>

</plugin>
“plugin.xml”实现了视图的扩展点“org.eclipse.ui.views”,Eclipse会根据扩展点的信息展现视图。


视图扩展点的实现类


在“Tree viewer”视图中要完成的功能有:树、菜单、工具栏和事件响应事件。“Tree viewer”视图的实现类为“TreeViewTest”,通过实现类能实现这些功能。
实现类中要完成如下的功能。
1. 初始化树。
2. 完成菜单和工具栏响应的Action。
3. 完成上下文菜单。
4. 完成工具栏。
5. 完成双击树节点的响应方式。
在createPartControl方法中能对视图进行初始化,代码片段如下。
public void createPartControl(Composite parent) {
//初始化树
viewer = new TreeViewer(parent, SWT.MULTI | SWT.H_SCROLL | SWT.V_SCROLL);
drillDownAdapter = new DrillDownAdapter(viewer);
viewer.setContentProvider(new ViewContentProvider());
viewer.setLabelProvider(new ViewLabelProvider());
viewer.setSorter(new NameSorter());
viewer.setInput(getViewSite());
//完成菜单和工具栏响应的Action
makeActions();
//完成上下文菜单
hookContextMenu();
//完成双击树节点的响应方式
hookDoubleClickAction();
//完成工具栏
contributeToActionBars();
}
通过实现类,用户能加入自己感兴趣的功能。“Tree viewer”视图中实现类的完整代码如例程2所示。
例程2 TreeViewTest.java
public class TreeViewTest extends ViewPart {
private TreeViewer viewer;
private DrillDownAdapter drillDownAdapter;
private Action action1;
private Action action2;
private Action doubleClickAction;
//创建树节点
class TreeObject implements IAdaptable {
private String name;
private TreeParent parent;

public TreeObject(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setParent(TreeParent parent) {
this.parent = parent;
}
public TreeParent getParent() {
return parent;
}
public String toString() {
return getName();
}
public Object getAdapter(Class key) {
return null;
}
}

class TreeParent extends TreeObject {
private ArrayList children;
public TreeParent(String name) {
super(name);
children = new ArrayList();
}
public void addChild(TreeObject child) {
children.add(child);
child.setParent(this);
}
public void removeChild(TreeObject child) {
children.remove(child);
child.setParent(null);
}
public TreeObject [] getChildren() {
return (TreeObject [])children.toArray(new TreeObject[children.size()]);
}
public boolean hasChildren() {
return children.size()>0;
}
}
//实现内容提供器
class ViewContentProvider implements IStructuredContentProvider,
ITreeContentProvider {
private TreeParent invisibleRoot;

public void inputChanged(Viewer v, Object oldInput, Object newInput) {
}
public void dispose() {
}
public Object[] getElements(Object parent) {
if (parent.equals(getViewSite())) {
if (invisibleRoot==null) initialize();
return getChildren(invisibleRoot);
}
return getChildren(parent);
}
public Object getParent(Object child) {
if (child instanceof TreeObject) {
return ((TreeObject)child).getParent();
}
return null;
}
public Object [] getChildren(Object parent) {
if (parent instanceof TreeParent) {
return ((TreeParent)parent).getChildren();
}
return new Object[0];
}
public boolean hasChildren(Object parent) {
if (parent instanceof TreeParent)
return ((TreeParent)parent).hasChildren();
return false;
}
//初始化树节点
private void initialize() {
TreeObject to1 = new TreeObject("Leaf 1");
TreeObject to2 = new TreeObject("Leaf 2");
TreeObject to3 = new TreeObject("Leaf 3");
TreeParent p1 = new TreeParent("Parent 1");
p1.addChild(to1);
p1.addChild(to2);
p1.addChild(to3);

TreeObject to4 = new TreeObject("Leaf 4");
TreeParent p2 = new TreeParent("Parent 2");
p2.addChild(to4);

TreeParent root = new TreeParent("Root");
root.addChild(p1);
root.addChild(p2);

invisibleRoot = new TreeParent("");
invisibleRoot.addChild(root);
}
}
//实现标签提供器
class ViewLabelProvider extends LabelProvider {

public String getText(Object obj) {
return obj.toString();
}
public Image getImage(Object obj) {
String imageKey = ISharedImages.IMG_OBJ_ELEMENT;
if (obj instanceof TreeParent)
imageKey = ISharedImages.IMG_OBJ_FOLDER;
return PlatformUI.getWorkbench().getSharedImages().getImage(imageKey);
}
}
class NameSorter extends ViewerSorter {
}

public TreeViewTest() {
}

public void createPartControl(Composite parent) {
viewer = new TreeViewer(parent, SWT.MULTI | SWT.H_SCROLL | SWT.V_SCROLL);
drillDownAdapter = new DrillDownAdapter(viewer);
viewer.setContentProvider(new ViewContentProvider());
viewer.setLabelProvider(new ViewLabelProvider());
viewer.setSorter(new NameSorter());
viewer.setInput(getViewSite());
makeActions();
hookContextMenu();
hookDoubleClickAction();
contributeToActionBars();
}
//提供右键菜单
private void hookContextMenu() {
MenuManager menuMgr = new MenuManager("#PopupMenu");
menuMgr.setRemoveAllWhenShown(true);
menuMgr.addMenuListener(new IMenuListener() {
public void menuAboutToShow(IMenuManager manager) {
TreeViewTest.this.fillContextMenu(manager);
}
});
Menu menu = menuMgr.createContextMenu(viewer.getControl());
viewer.getControl().setMenu(menu);
getSite().registerContextMenu(menuMgr, viewer);
}
//提供视图工具栏
private void contributeToActionBars() {
IActionBars bars = getViewSite().getActionBars();
fillLocalPullDown(bars.getMenuManager());
fillLocalToolBar(bars.getToolBarManager());
}

private void fillLocalPullDown(IMenuManager manager) {
manager.add(action1);
manager.add(new Separator());
manager.add(action2);
}
//填充菜单
private void fillContextMenu(IMenuManager manager) {
manager.add(action1);
manager.add(action2);
manager.add(new Separator());
drillDownAdapter.addNavigationActions(manager);
// Other plug-ins can contribute there actions here
manager.add(new Separator(IWorkbenchActionConstants.MB_ADDITIONS));
}

private void fillLocalToolBar(IToolBarManager manager) {
manager.add(action1);
manager.add(action2);
manager.add(new Separator());
drillDownAdapter.addNavigationActions(manager);
}
//创建菜单和工具栏对应的Action
private void makeActions() {
action1 = new Action() {
public void run() {
showMessage("Action 1 executed");
}
};
action1.setText("Action 1");
action1.setToolTipText("Action 1 tooltip");
action1.setImageDescriptor(PlatformUI.getWorkbench().getSharedImages().
getImageDescriptor(ISharedImages.IMG_OBJS_INFO_TSK));

action2 = new Action() {
public void run() {
showMessage("Action 2 executed");
}
};
action2.setText("Action 2");
action2.setToolTipText("Action 2 tooltip");
action2.setImageDescriptor(PlatformUI.getWorkbench().getSharedImages().
getImageDescriptor(ISharedImages.IMG_OBJS_INFO_TSK));
doubleClickAction = new Action() {
public void run() {
ISelection selection = viewer.getSelection();
Object bj = ((IStructuredSelection)selection).getFirstElement();
showMessage("Double-click detected on "+obj.toString());
}
};
}

private void hookDoubleClickAction() {
viewer.addDoubleClickListener(new IDoubleClickListener() {
public void doubleClick(DoubleClickEvent event) {
doubleClickAction.run();
}
});
}
private void showMessage(String message) {
MessageDialog.openInformation(
viewer.getControl().getShell(),
"Tree View",
message);
}
//响应获得焦点
public void setFocus() {
viewer.getControl().setFocus();
}
}
上例中通过内容提供器(ViewContentProvider)、标签提供器(ViewLabelProvider)及树节点(TreeObject)的定义提供了树的实现,另外通过createPartControl方法实现了相应的菜单和工具栏。
提示:本例中右键菜单和工具栏的实现方式非常值得效仿,而且非常直观,读者可以比较一下在SWT中的实现方式,找到它们之间的异同点。


运行“Tree viewer”视图


“Tree viewer”插件到此就已经完成,现在可以调试插件了。
1. 运行插件。
2. 打开运行时工作台的“Show View”。
在“Show View”窗口中可以看到前面建立的分类和视图节点。
3. 运行“Tree viewer”视图
双击“Tree View”节点,打开视图窗口,如图4所示。


图4 “Tree viewer”视图


在Eclipse插件的开发中,视图插件的开发是比较重要的一个部分。视图是工作台页面内的可视组件,用户可以通过视图,扩展Eclipse原有的功能。

分享到:
评论

相关推荐

    java 开发视图插件(View) eclipse

    Java开发视图插件在Eclipse中的应用是一个关键的话题,特别是在构建复杂的集成开发环境中。Eclipse作为一个开源且功能强大的Java IDE,提供了丰富的扩展机制,允许开发者通过插件自定义工作台视图,以满足特定的开发...

    Jquery 视图插件,模板插件,日期插件 案例

    在这个“Jquery 视图插件,模板插件,日期插件 案例”中,我们将深入探讨jQuery如何通过扩展增强其在用户界面呈现和管理上的能力。以下是关于这些主题的详细讨论: 1. **jQuery 视图插件**: jQuery视图插件通常...

    java swt eclipse视图插件

    "java swt eclipse视图插件"可能指的是利用SWT技术开发的Eclipse视图插件,这种插件能够增强Eclipse的工作区视图,提供新的功能或优化现有功能的显示方式。 "SWT_Designer_for_Eclipse"很可能是一个工具,帮助...

    CAD窗口视图预览插件插件

    标题中的“CAD窗口视图预览插件插件”是指一个专门针对CAD软件开发的增强功能插件,其主要目标是提供一个直观、实时的视图预览界面,帮助用户在不打开完整文件的情况下查看CAD图形的内容。这种插件通常具备以下特点...

    金蝶云苍穹_插件开发指南

    金蝶云苍穹插件开发指南知识点 金蝶云苍穹插件开发指南是一份详细的开发文档,旨在指导开发者如何开发金蝶云苍穹插件。下面是该指南中的主要知识点: 1. 插件开发的必要性:插件可以扩展金蝶云苍穹的功能,使其...

    dede插件开发教程

    【dede插件开发教程】 在内容管理系统(CMS)中,dede是一个广泛使用的平台,以其灵活的模板引擎和强大的自定义能力深受开发者喜爱。如果你希望通过二次开发来拓展dede的功能,本教程将引导你逐步了解如何进行dede...

    Revit二次开发,创建任意视角的3d视图

    在Revit的二次开发中,通常会使用Visual Studio作为开发环境,创建一个Revit插件项目,然后引用Revit API库。 在代码实现上,首先需要获取到Revit的当前文档对象,这是所有操作的基础。接着,使用`Document.Create....

    fvs最新可视化视图插件

    在软件开发领域,可视化视图插件通常用于数据处理、项目管理、代码编辑等多种场景。fvs最新版本可能包含了多项改进和增强,例如: 1. **增强的数据可视化**:该插件可能新增了多种图表类型,如折线图、柱状图、饼图...

    eclipse 插件开发01

    第二篇是插件开发核心技术,主要介绍插件开发的核心知识要点,包括行为(Action)、视图(ViewPart)、编辑器(Editor)、透视图(Perspective)等10章的内容;第三篇主要讲述插件开发的高级内容,包括开发高级内容...

    Eclipse插件开发学习笔记.pdf

    Eclipse插件开发是扩展Eclipse功能的重要方式,开发者可以通过编写插件来增加Eclipse平台的自定义功能,从而提升开发效率,定制个性化的开发环境。Eclipse插件开发学习笔记将带领我们深入了解Eclipse插件开发的...

    开发 Eclipse 插件 快速入门

    开发 Eclipse 插件快速入门是针对想要学习如何在 Eclipse 环境中创建自定义功能扩展的开发者。Eclipse 插件是构建可扩展集成开发环境(IDE)的关键,允许开发者构建与 Eclipse 和其他工具无缝集成的工具。本文由 ...

    Eclipse插件开发教程PPT Eclipse插件开发教程PPT

    10. **调试支持**:Eclipse的调试框架允许开发插件以扩展调试功能,如添加新的断点类型或提供自定义调试视图。 通过深入学习和实践Eclipse插件开发教程PPT中的内容,开发者不仅可以提升自身技能,还能更好地利用...

    金蝶云苍穹_插件开发指南.docx

    金蝶云苙穹插件开发指南 金蝶云苙穹插件开发指南是金蝶软件(中国)有限公司发布的一份插件开发指南,旨在帮助开发者快速掌握金蝶云苙穹插件的开发技术。下面是该指南中涉及的一些重要知识点: 1. 插件开发的必要...

    月视图和周视图切换控件

    综上所述,“月视图和周视图切换控件”不仅提供了一个直观且易于使用的界面来展示和管理日程安排,同时也展示了如何利用 C# 和 Windows Forms 平台来开发自定义控件的过程。对于那些希望在自己的应用程序中加入类似...

    IntelliJ IDEA插件开发基础(中文).pdf

    10. **Debugging Support**:插件可以扩展调试器,添加新的断点类型、变量视图等,以提升调试体验。 11. **UI组件**:通过使用`com.intellij.ui`包中的组件,可以创建自定义的GUI工具窗口和对话框。 12. **发布与...

    Eclipse插件开发文档

    例如,开发一个显示当前时间的视图插件: 1. 创建视图类,继承自JFace的ViewPart类,实现draw视图内容的方法。 2. 在plugin.xml中声明视图的扩展点,指定ID、名称和图标。 3. 在运行时工作台启动插件,通过菜单或...

    开发Eclipse插件之天气预报

    在IT行业中,开发Eclipse插件是一个非常实用的技能,特别是在软件工程领域,因为Eclipse作为一款强大的集成开发环境(IDE),广泛应用于Java及其他语言的开发。本篇将基于"开发Eclipse插件之天气预报"这个主题,深入...

    Eclipse插件开发系列

    Eclipse插件开发系列主要涉及的是如何利用Eclipse平台进行扩展和定制,使其满足特定的开发需求。Eclipse作为一个开放源代码的集成开发环境(IDE),具有强大的可扩展性,其核心架构支持通过插件机制来增加新功能或...

Global site tag (gtag.js) - Google Analytics