月蚀传说

浮躁让人失去理智
posts - 25, comments - 101, trackbacks - 0, articles - 0
  BlogJava :: 首页 ::  :: 联系 :: 聚合  :: 管理

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

1.内容帮助简介

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

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



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

2.创建XML Editor

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



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



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, 0new String("替换文本1").length(), null"帮组内容1"null,null) ;
        proposals[
1= new CompletionProposal("替换文本2", offset, 0new 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();
        
// 让帮助内容在XML的Tag标签范围内激%

评论

# re: Eclipse plugin开发之TextEditor —— 如何实现文本内容帮助  回复  更多评论   

2006-12-08 13:15 by 河风
Good THX

# re: Eclipse plugin开发之TextEditor —— 如何实现文本内容帮助  回复  更多评论   

2007-03-30 19:54 by ffxiangyu
最后一个方法是不是缺一段?

# re: Eclipse plugin开发之TextEditor —— 如何实现文本内容帮助  回复  更多评论   

2007-07-25 02:28 by Acan
对啊!关键的一段缺了,吊胃口!

只有注册用户登录后才能发表评论。


网站导航: