定制Eclipse IDE之界面篇

为何要定制IDE?html

     在工做时候,当公司有了本身的框架,给本身开放人员用,甚至是能够卖的时候,咱们能够作成一个产品,而这个产品将包括框架自己、文档、工具、教程等等。工具之中最重要的莫过于开发工具(IDE)、调试工具。
     我在公司里面作的是一个hybrid框架,而一个配套的IDE是比不可少的,主要用来开发HTML5。这个IDE能够算是框架东西的聚合,能够将在线文档、工程模板、打包调试等功能都揉合在IDE。当咱们提供给开发者东西时,咱们只须要提供一个IDE,里面已经包含全部框架的东西。
     我花费了一个月去作这个IDE,基于Eclipse来作。之因此用Eclipse不用什么dreamweaver、notepad++等,是由于这些看起来不专业,可拓展的东西也是有限。目前apicloud或dcloud这些hybrid框架都是基于Eclipse作定制的,只不过dcloud作得比较完全。
     我就把我这个月的开发经历一并告诉你们。
 
怎么定制IDE?
     咱们之因此可以定制Eclipse IDE,并非咱们写的东西有多厉害,而是Eclipse的自己,它是一个平台,可以让咱们编写插件拓展功能,达到支持各类语言编辑的IDE。在Eclipse官方下载有不少版本的Eclipse,能够说这就是不一样插件组装而成的。因此咱们定制IDE,其实就是编写Eclipse插件 (Eclipse plug-in)。
 
IDE定制成什么样?
     下面就是这一个月来定制最后的结果,我将从结果讲解,这个东西怎么一步步搭起来的(支持windows、mac的IDE)。另外里面出现BingoTouch的名称是我开放框架,你们能够忽略。从下面能够看到咱们须要定制菜单栏、工具栏、视图区。
     这里讲一个很关键的概念就是透视图(perspective),透视图能够当作一种编辑视图,咱们熟知的可能有Java、debug(能够经过右上角切换透视图),一切的东西均可以在透视图上设置,类如设置菜单栏、工具栏有什么,视图区是由什么构成的。
  
手动定制界面过程
接下来我将讲对界面一些定制的细节,注意里面列举的目录要按你使用eclipse决定,可能版本会不一样。
(1). 启动页
启动页是一个门面,咱们可将他换成能够体现本身产品的图片。
替换过程:
对应目录 eclipse\plugins\org.eclipse.platform_4.4.2.v20150204-1700\splash.bmp,只须要换这张图片便可。
 
(2). IDE图标
这些图标的尺寸分别是16*1六、32*3二、48*4八、256*256,是用来作应用图标或IDE窗口图标,咱们只须要替换这四个尺寸的图标便可使得整个IDE大变样。
替换过程:
对应目录 eclipse\plugins\org.eclipse.epp.package.rcp_4.4.2.20150219-0708
对应目录 eclipse\plugins\org.eclipse.platform_4.4.2.v20150204-1700
覆盖掉里面的eclipse16.png,eclipse32.png,eclipse48.png,eclipse256.png 替换便可。
 
(3) . eclipse.exe图标
当咱们想把图标换得更完全的时候,即连eclipse.exe图标都换。我在网上找了不少工具,却发现要么不行、要么只替换了某个大小尺寸的。最后找到一个工具IconWorkshopshiyongban 。用IconWorkshopshiyongban 修改exe图标,这个才是最直接完整的工具。
替换过程:
1. 用IconWorkshopshiyongban 打开 eclipse.exe,咱们看到下面界面,咱们第二步用的图标又派上用场了(尺寸如出一辙)。
2. 而后用这个工具打开那四个不一样尺寸的图标,会获得下面界面。
3.双击 eclipse.exe里面任一图标,而后用复制粘贴的办法覆盖掉全部尺寸图标。
4.保存便可,就会发现exe的图标已经换了,在不一样尺寸下都显示正常。
ps:可能会出现图标会没替换到的样子,这时你能够换个目录来看,就正常的,那只是应用图标没刷新而已。
 
(4). Eclipse.icns
这个是mac上Eclipse的应用图标,路径以下(咱们也要输出mac的IDE)。
替换过程:
其实替换过程跟eclipse.exe同样,只不过须要的尺寸多了两个512* 5十二、1024*1024。
PS:若是发现启动程序后,发现任务栏的应用图标变暗变模糊了,就须要在icns文件加上128*128尺寸的。
 
 
插件定制界面过程
上面介绍的是手动更换界面的办法,而接下来就是介绍插件改变界面的东西。我推荐使用eclipse-rcp-and-rap-developers这个Eclipse做为开放插件的IDE。
(1). 插件hello world工程
在讲插件改变界面时,简单介绍一下建立插件的过程。
因为篇幅比较长,因此就写在另一篇文章,请查看: Eclipse Plug-in Hello world
 
(2). IDE标题
在第一个张图片中,咱们能够看到IDE标题是,BingoTouch - welcome - BingoTouch IDE,这个标题是由三部分组成的,透视图名称- 编辑区名称 - 产品名称。其中透视图和编辑区的名称都好理解,而产品名称是在eclipse\plugins\org.eclipse.epp.package.rcp_4.4.2.20150219-0708\plugin.xml里面定义的。因此IDE的名称并非固定的,是由这三部分组成,咱们也没必要去改它们。
 
(3). 隐藏菜单栏、工具栏
不少时候,菜单栏或工具栏上的一些功能图标咱们并不须要,为了使IDE看起来比较简洁,咱们须要隐藏一些菜单、工具栏图标。我在前面说过,IDE整个界面关键的是透视图,菜单栏、工具栏的隐藏只是对于某个透视图来讲的,例如你定制本身的透视图,其余透视图是不会影响到的。
隐藏代码:
<extension
    point="org.eclipse.ui.perspectiveExtensions" >
    <perspectiveExtension
        targetID="com.bingo.ide.perspective" >
            <hiddenMenuItem id="org.eclipse.ui.file.export"/>
            <hiddenToolBarItem id="org.eclipse.mylyn.tasks.ui.command.openTask"/>
    </perspectiveExtension>
</extension>
解析:
hiddenMenuItem :隐藏菜单栏
hiddenToolBarItem : 隐藏工具栏
1.这个两个标签是写在拓展点(extension point)里面的,targetID是指明对哪一个透视图生效。这里面有个关键的地方,就是id的获取,菜单栏、工具栏的选项对应的id是什么,这是很是关键的。
2.我收集了Eclipse 经常使用的Id,一样由于篇幅缘由,我把他收集在另外一篇文章中: Eclipse 扩展点常量ID
3.可能有人会发现,上面常量ID可能不够,有些咱们想隐藏的没有在里面,那怎么办。办法老是有的,只要你寻找。我用了一种比较蠢但能解决问题的办法,一样由于篇幅缘由,我把他写在另外一篇文章中: Eclipse 寻找迷失的ID
 
(4). 删除透视图
有些透视图也是咱们不想要的,例以下面这些透视图咱们不想在定制的IDE出现。
 
透视图也是插件实现的,因此咱们只须要删除相应的插件就行,例如咱们想删除Git的透视图,在eclipse\plugins目录搜索git关键字。将这两个包删掉,再次打开IDE时候,你会发现Git的透视图不见了。因此请记住,删透视图便是删插件。
 
(5). 视图定义
视图定义从下图可看到有三部分,左边是项目管理视图,右上是编辑视图,右下是控制台视图
这视图的定义能够用xml定义,也能够用代码。我建议是用代码,由于这个自由度更高。
 
String editorArea = layout.getEditorArea();
//添加视图
layout.addView(IPageLayout.ID_PROJECT_EXPLORER, IPageLayout.LEFT, 0.22f, editorArea);

IFolderLayout bottom =layout.createFolder("bottom", IPageLayout.BOTTOM, 0.75f , editorArea) ;
bottom.addView("org.eclipse.ui.console.ConsoleView"); 
//bottom.addView(IPageLayout.ID_PROBLEM_VIEW);

IViewLayout projectLayout = layout.getViewLayout(IPageLayout.ID_PROJECT_EXPLORER);
projectLayout.setCloseable(false);
projectLayout.setMoveable(false);
解析:
其实代码都比较好理解,不要使用xml配置,在代码里面写,能够添加一个folder包含多个窗口。
 
(6). 删除启动欢迎页
有可能你不须要首次打开时显示欢迎页,你能够这样删除它。
eclipse\plugins\org.eclipse.epp.package.rcp_4.4.2.20150219-0708\plugin.xml
删除:
<extension
     point="org.eclipse.ui.intro">
    <introProductBinding
         introId="org.eclipse.ui.intro.universal"
          productId="org.eclipse.platform.ide">
    </introProductBinding>
</extension>

 

这篇文章篇幅太长了,先介绍到这里,下一篇继续讲解。
 

本文为原创文章,转载请保留原出处,方便溯源,若有错误地方,谢谢指正。
本文地址 :http://www.cnblogs.com/lovesong/p/4693467.htmlgit