第一章 创建一个GEF Editor插件

 

1.1 向导   

 创建一个Plug-In Development->Plug-In Project,中间选择一路next直到选择模板的时候什么也不选择,直接按Finish。此时创建了一空的插件项目。

    之后删除META-INF目录,然后在项目文件夹下新建plugin.xml文件,在文件中输入:

xml 代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <?eclipse version="3.0"?>  
  3. <plugin>  
  4. </plugin>  

保存plugin.xml后,就建立了一个空的配置文件。

    这里首先解释为什么要删除MANIFEST.MF文件,而创建plugin.xml文件?因为在插件在执行的时候,eclipse平台根据 plugin.xml中的信息配置插件,如果plugin.xml和MANIFEST.MF同时存在,那么eclipse将不能正确载入插件。这是因为有 些信息一旦在MANIFEST.MF记录,就不会再写入plugin.xml。当然,我没有试过单独使用manifest.mf配置插件。

    这个时候查看一下eclipse为我们创建的文件,在src下有一个包和一个文件,这些都是在向导中设置的,如果向导中是胡乱填写的也没有关系,可以将它们删除,然后自己创建。这些文件的作用稍后再介绍,下面讲述如何配置plugin.xml。

 

1.2 配置plugin.xml   

 plugin.xml是插件项目的配置文件,eclipse根据这个文件中记录的信息来在如何管理插件。这个文件中记录了插件的扩展点、主类等重 要信息,对于新建的插件项目,首先就应该要配置这个文件。如果你使用的是manifest.mf,配置的过程基本上类似,这里不再说明。

    双击plugin.xml,进入一个编辑界面,该界面下方有一些切换页,包括Overview、Dependencies、Runtime、Extensions、Extension Point、Build等。我们按照顺序依次进行说明和配置。

1.2.1 Overview页   

这个页中主要包括了插件的基本信息,同时也包括了一些其他页的连接。

    这个页面中最重要的内容就是设置General Infomation中的class项,至于General Infomation中的其他项,可以根据自己的需要填写,不会影响插件的功能。这个class项就是插件的载入主文件,也就是向导中为我们创建的而被我 们删除的(也可以不删除)文件,如果你刚才删除了那个文件,这个时候就需要根据你的需要重新创建一个主文件。在class项中填写你的主文件名就可以了, 如果填写错误,那么插件将不能正确工作。

1.2.2 Dependencies页    Dependencies页中设定了你编写的插件需要用到那些模块和插件,这是由于eclipse的扩展机制所决定的。对于基于GEF的编辑器插件,一般来说应包括:
org.eclipse.core.runtime
org.eclipse.gef
org.eclipse.ui
org.eclipse.ui.views
这几个插件。你可以通过点击Add按钮增加新的插件依赖,通过remove删除插件依赖。至于其他插件项目需要使用哪些依赖,请查看相应的资料,我并没有对这一问题有过深究。

1.2.3 Runtime页 

   这里是用来设置插件运行时的类库文件,是一个jar文件。点击New增加新的文件,输入你想要的文件名。

    这一步骤比较简单,但是这里输入的类库文件决定了Build页中的内容,这一问题等到Build页在详细说明。

1.2.4 Extensions页  

  这个页面里面包含了很重要的设置,它用来描述插件扩展了怎样的功能。点击Add会增加一个扩展,对于一个GEF编辑器插件,一般来说应该选择org.eclipse.ui.editors,注意不要选择Available Templates。

    选中新建的条目,右键点击该条目,选择new->editor(对于org.eclipse.ui.editors),就会增加一个editor条 目(不同的扩展会有不同的选择)。选中这个条目,旁边的Extension Element Details就会出现关于这个条目的信息。下面来说明一下主要应该填写的内容:
    id:插件的ID,随便什么都行,只要不重复,不妨设置为你的主文件名。
    name:插件的名字,随便起好了。
    icon:插件的图标,这个就随意了,可以不填。
    extensions:插件的扩展名,这就好像是在eclipse上为打开的文件和插件之间建立一个映射,文件的扩展名为这个的时候eclipse启用这个插件进行编辑。这个非常重要。
    class:最重要的设置,在这里填写实现了插件主控制器的类。简单来说,这个类告诉eclipse如何创建GEF插件的主界面。必须填写这个类,但是我们还没有建立这个类,因此可以暂时留空。
    command:不知道用途,可以不填。
    launcher:不知道用途,感觉上好像是启用插件的加载器,可以不填。
    contributorClass:实现工具栏的类,可以不填,如果你不需要工具栏的话(事实上还有另一种方法实现工具栏的大部分功能,在后面介绍调色板的时候再说明)。

    剩余的使用默认值就可以了。

1.2.5 Extension Points页   

 这一页的功能还没有搞清楚,在实践当中好像不是必须的,因此可以不填。

1.2.6  Build页  

  在这里要配置如何生成插件,这个页中的内容和Runtime中的有关。选择Add Library输入在Runtime页中输入的类库名,并且删除默认的build项目(也可以直接rename)。在选中新建的类库,点击右边的Add Folder,选中源文件的目录并确定。这样将源文件加入到编译输入中。再在Binary Build中选择plugin.xml,这就大功告成了。

1.2.7  小结   

配置PlugIn.xml的工作基本完毕(注意除了没有填写Extensions页中的class项:P)。但是插件此时并不能工作,因为我们还没 有编写两个关键的文件,一个就是插件的主文件,另一个就是插件的主界面文件(姑且这么称呼吧)。  下面就是要介绍如何编写这两个文件,以及基本的代码实现。

你可能感兴趣的:(第一章 创建一个GEF Editor插件)