Eclipse plugin开发 —实现文本内容帮助

本文介绍了如何在Eclipse插件开发中为XML Editor添加内容帮助功能,通过复写XMLConfiguration类的方法并实现IContentAssistProcessor接口,以在输入特定字符时提供代码提示。主要内容包括创建ContentAssistant,设置激活字符,以及生成CompletionProposal。
摘要由CSDN通过智能技术生成

http://blog.sina.com.cn/s/blog_40585f8d010009lw.html看到一篇文章,但是程序不完整,特此做一些修改:

大家在使用Eclipse编写Java代码的时候,一定被Java代码编辑器的强大功能所吸引:出色的错误提示,准确的内容帮助,文本的折叠等等。今天我以Eclipse插件中的XML Editor例子作为模板,为XML文本编辑器加入内容帮助(Content Assis)。

1.内容帮助简介

在目前流行的IDE中,内容提示帮助是必不可少的功能,可以说,如果没有了内容帮助,那IDE就不能称为IDE。有了内容帮助提示,能大大提高代码编写速度。

请看下图:当我们在Java编辑器中输入‘.’的时候,就会弹出一个菜单,里面列出了类所具有的方法以及属性,并且在我们继续输入字符的时候,弹出的内容会随着我们的输入进行过滤。

Eclipse <wbr>plugin开发之TextEditor <wbr>鈥斺 <wbr>如何实现文本内容帮助

下面我们以Eclipse的XML Editor Example为例,介绍一下内容帮助如何实现的。

2.创建XML Editor

我们首先需要建立一个Plugin工程,然后在向导页中选择我们要生成的XML Editor例子:

Eclipse <wbr>plugin开发之TextEditor <wbr>鈥斺 <wbr>如何实现文本内容帮助



点Finish完成,这时候我们的工程便生成了,并且向导还为我们生成了XML Editor所需要的一些类,以及为我们的Plugin.xml实现了org.eclipse.ui.editors扩展点:

Eclipse <wbr>plugin开发之TextEditor <wbr>鈥斺 <wbr>如何实现文本内容帮助



3.简单的内容帮助

在我们生成的类中,有一个名为XMLConfiguration的类,该类对XML Editor进行了一些设置,包括如何去为不同的文本区域显示不同的颜色等,TextEditor所维护的SourceViewer就是通过它来进行设置的,但这不是我们所要讨论的范围,这里简单地介绍一下即可。

接下来我们需要复写XMLConfiguration的一个方法:getContentAssistant。这个方法便是告诉我们的编辑器,我们所具有的内容帮助是什么,在创建XML Editor的时候,默认是不为我们生成这方面代码的,所以我们需要自己复写:

      public   IContentAssistant getContentAssistant(ISourceViewer sourceViewer) {
          //   生成一个ContentAssistant 
        ContentAssistant assistant   =      new   ContentAssistant();
 
          //   设置帮组内容弹出响应时间 
        assistant.setAutoActivationDelay(  200  );
        assistant.enableAutoActivation(  true  );
          return   assistant;
    }


ContentAssistant并不是内容帮助的提供者,它只是维护我们的内容帮助,帮我们弹出菜单以及帮助内容信息等作用。
真正告诉ContentAssistant要显示那些帮助内容的,是IContentAssistProcessor接口类。让我们创建一个名为StrutsContentAssisProcessor的类,并让它实现IContentAssistProcessor接口:

public   class  StrutsContentAssisProcessor implements IContentAssistProcessor {

     public  ICompletionProposal[] computeCompletionProposals(ITextViewer viewer,
             int  offset) {
         return   null ;
    }

     public  IContextInformation[] computeContextInformation(ITextViewer viewer,
             int  offset) {
         return   null ;
    }

     public   char [] getCompletionProposalAutoActivationCharacters() {
         return   null ;
    }

     public   char [] getContextInformationAutoActivationCharacters() {
         return   null ;
    }

     public  String getErrorMessage() {
         return   null ;
    }

     public  IContextInformationValidator getContextInformationValidator() {
         return   null ;
    }

}


大家注意下computeCompletionProposals方法,这个方法便是返回我们的具体内容帮助。所以我们需要为我们的编辑器创建所需要的内容帮助:CompletionProposal

先看一下这个类的构造函数各个参数的含义:

     * @param replacementString :选择帮助信息后所要替代的文本内容
      *  @param replacementOffset :替代内容输入的位置
      *  @param replacementLength :替代文本覆盖原来文本的长度   
      *  @param cursorPosition :完成内容帮助的文本替代后,光标所在位置
      *  @param image :帮助内容显示的图标
      *  @param displayString :帮助内容的显示字符串
      *  @param contextInformation :帮助内容的信息描述
      *  @param additionalProposalInfo :附加信息


在这几个参数中image 、contextInformation、additionalProposalInfo我们可以设置为空。现在让我们在computeCompletionProposals生成我们的帮助内容:

  public  ICompletionProposal[] computeCompletionProposals(ITextViewer viewer,
             int  offset) {
        ICompletionProposal[] proposals  =   new  ICompletionProposal[ 2 ];
        
        proposals[ 0 ]  =   new  CompletionProposal( " 替换文本1 " , offset,  0 ,  new  String( " 替换文本1 " ).length(),  null ,  " 帮组内容1 " ,  null , null ) ;
        proposals[ 1 ]  =   new  CompletionProposal( " 替换文本2 " , offset,  0 ,  new  String( " 替换文本2 " ).length(),  null ,  " 帮组内容2 " ,  null , null ) ;
        
         return  proposals;
    }


computeCompletionProposals输入的参数中 offset是指当内容帮助弹出的时候,文本编辑器光标所在位置。

大家都知道,帮助内容弹出的时候是需要一定条件的,也就是当我们输入了激活内容帮助的字符的时候,它便会弹出来。IContentAssistProcessor 的getCompletionProposalAutoActivationCharacters方法便是让我们返回激活帮助内容字符的,假设当我们输入了‘<’时,弹出帮助内容:

   public char[] getCompletionProposalAutoActivationCharacters() {
        return new String("<").toCharArray();
    }

好了,我们的第一步已经完成了,接下来就是在ContentAssis对象中设置我们所要返回的内容帮助。
返回到XMLConfiguration的getContentAssistant方法:

    

public IContentAssistant getContentAssistant(ISourceViewer sourceViewer) {
// 生成一个ContentAssistant
ContentAssistant assistant = new ContentAssistant();

// 设置帮组内容弹出响应时间
assistant.setAutoActivationDelay( 200 );
assistant.enableAutoActivation( true );
assistant.setContentAssistProcessor(new StrutsContentAssisProcessor(), IDocument.DEFAULT_CONTENT_TYPE);

return assistant;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值