GEF七天之第五天

    今天写两篇,后天去北京,所以近期可能很少来园子里了,呵呵!!!

     之前我们以一个小DEMO的形式介绍了GEF的model,Controller的实现,今天我们就来介绍gef中MVC的最后一个----view,即视图.由于我们这个DEMO是一个eclipse plug-in程序.所以他视图部分用的知识大部分是eclipse plug-in的相关知识(涉及的eclipse plug-in的相关知识我们将不作说明).

      通常我们用eclipse 的Editor作为主要视图,我们必须扩展org.eclipse.ui.editors这个扩展点,这个可以在plugin.xm 定义,定义后的文件如下:

 

Code

 

其中,class属性指定我们编辑器对应的类;
           Extensions属性指定编辑器打开文件的扩展名为workflow;
           Default属性指出该编辑器是扩展名为workflow文件的默认打开方式;
           Icon为扩展名为workflow的文件和编辑器的图标;
           Id属性为编辑器的唯一标识
          Name为编辑器显示的名称

      然后我们定义编辑器的主界面类ShapesEditor,他继承GraphicalEditorWithFlyoutPaletteGraphicalEditorWithFlyoutPalette是带有面板的图形化编辑器.我们先来看看ShapesEditor的代码

Code

 

 

在这个类getPaletteRoot()方法中,创建了面板。

在setInput方法中,定义了一个DiagramModel对象;

在构造函数中setEditDomain(new DefaultEditDomain(this));就是给当前编辑器设置一个默认编辑域,这个域跟命令堆栈有关。

initializeGraphicalViewer()方法,把GraphicalViewer的内容设计为DiagramModel,说明后编辑的是一个DiagramModel,并且添加了监听以监听用户的请求(用createTransferDropTargetListener方法建立监听

在configureGraphicalViewer(),注册控制器工厂,并通过ContextMenuProvider来创建右肩菜单。

getAdapter(Class type)在此方法中创建大纲视图,大纲视图的相关创建我们以后再说明.

建立大纲和建立面板以后我们会做详细说明

这是视图界面截图:

posted @ 2008-07-29 23:15    阅读(1532)  评论(2编辑  收藏  举报