亚洲成人一区在线观看_天堂网www_国产精品久久9_中文在线播放_伊人天天_久久精品久久久精品美女

當(dāng)前位置:首頁 > 網(wǎng)站舊欄目 > 學(xué)習(xí)園地 > 設(shè)計(jì)軟件教程 > JFace Text Editor完全掌握之終極指南(4)

JFace Text Editor完全掌握之終極指南(4)
2010-01-14 23:09:22  作者:  來源:

錯誤標(biāo)識(Error Marking)
Error Marking用來對編輯的文檔根據(jù)一定的規(guī)則進(jìn)行驗(yàn)證,比如對于XML文檔來說,可能是XML DTD或者XML Schema.其實(shí)現(xiàn)跟內(nèi)容大綱比較類似,首先在解析文檔的時候?qū)rror加以標(biāo)識.這里我們使用了SAX ErrorHandler來收集和定位所有的error, 接著在生成內(nèi)容大綱的同時進(jìn)行驗(yàn)證和error marking,這個工作在文檔被加載和文檔保存的時候都會進(jìn)行.

Support for error marking in the enhanced XML editor 
在XMLEditor的validateAndMark()方法中完成對error marking的初始化:

 

java 代碼
 
  1. protected void validateAndMark()   
  2. {   
  3.   
  4.     IDocument document = getInputDocument();   
  5.     MarkingErrorHandler markingErrorHandler =    
  6.      new MarkingErrorHandler(getInputFile(), document);   
  7.     markingErrorHandler.removeExistingMarkers();   
  8.   
  9.     XMLParser parser = new XMLParser();   
  10.     parser.setErrorHandler(markingErrorHandler);   
  11.   
  12.     String text = document.get();   
  13.     parser.doParse(text);   
  14.   
  15. }  

MarkingErrorHandler的實(shí)例化需要兩個參數(shù):一個是IFile實(shí)例,用來執(zhí)行marking(Eclipse Marker API將通過IFile來引用底層的Resource對象),另一個是編輯的IDocument實(shí)例(用來確定插入到文檔中的marker的位置)

在文檔被解析之前,已有的error marker都必須先清掉, 在解析文檔的時候如果發(fā)現(xiàn)錯誤,將調(diào)用MarkingErrorHandler的handleError()方法:

java 代碼
 
  1. protected void handleError(SAXParseException e, boolean isFatal)   
  2. {   
  3.   
  4.     int lineNumber = e.getLineNumber();   
  5.     int columnNumber = e.getColumnNumber();   
  6.   
  7.     Map map = new HashMap();   
  8.     MarkerUtilities.setLineNumber(map, lineNumber);   
  9.     MarkerUtilities.setMessage(map, e.getMessage());   
  10.     map.put(IMarker.MESSAGE, e.getMessage());   
  11.     map.put(IMarker.LOCATION, file.getFullPath().toString());   
  12.   
  13.     Integer charStart = getCharStart(lineNumber, columnNumber);   
  14.     if (charStart != null)   
  15.         map.put(IMarker.CHAR_START, charStart);   
  16.   
  17.     Integer charEnd = getCharEnd(lineNumber, columnNumber);   
  18.     if (charEnd != null)   
  19.         map.put(IMarker.CHAR_END, charEnd);   
  20.   
  21.     map.put(IMarker.SEVERITY, new Integer(IMarker.SEVERITY_ERROR));   
  22.   
  23.     try  
  24.     {   
  25.         MarkerUtilities.createMarker(file, map, ERROR_MARKER_ID);   
  26.     }   
  27.     catch (CoreException ee)   
  28.     {   
  29.         ee.printStackTrace();   
  30.     }   
  31. }   
  32.   

這里我們的編輯器通過XML解析器(Xerces)不僅取得了error信息,而且還得到了發(fā)生錯誤的位置信息,因此上面的代碼看起來非常的清晰:首先取得錯誤信息的行號和列號,然后使用Eclipse Marker API創(chuàng)建一個Error Marker

內(nèi)容輔助
最后我們將要介紹的一個功能是內(nèi)容輔助, 下圖是我們的實(shí)現(xiàn)效果, 這里我們只是一個簡單的實(shí)現(xiàn),對于一個商業(yè)的XML編輯器來說,更強(qiáng)悍的就是能夠根據(jù)當(dāng)前光標(biāo)的位置以及定義的DTD做更精確的內(nèi)容輔助

Support for content assist in the enhanced XML editor 

為了讓我們的內(nèi)容輔助功能做的更智能,我們需要知道當(dāng)前文檔的結(jié)構(gòu)以及當(dāng)前光標(biāo)在文檔結(jié)構(gòu)中的位置

跟其他功能類似,內(nèi)容輔助功能也是通過SourceViewerConfiguration來提供的,下面是我們的實(shí)現(xiàn)代碼:

java 代碼
 
  1. public IContentAssistant getContentAssistant(ISourceViewer sourceViewer)   
  2. {   
  3.   
  4.     ContentAssistant assistant = new ContentAssistant();   
  5.   
  6.     IContentAssistProcessor tagContentAssistProcessor    
  7.         = new TagContentAssistProcessor(getXMLTagScanner());   
  8.     assistant.setContentAssistProcessor(tagContentAssistProcessor,   
  9.             XMLPartitionScanner.XML_START_TAG);   
  10.     assistant.enableAutoActivation(true);   
  11.     assistant.setAutoActivationDelay(500);   
  12.     assistant.setProposalPopupOrientation(IContentAssistant.CONTEXT_INFO_BELOW);   
  13.     assistant.setContextInformationPopupOrientation(IContentAssistant.CONTEXT_INFO_BELOW);   
  14.     return assistant;   
  15.   
  16. }   
  17.   

上面的代碼比較簡單,首先創(chuàng)建一個ContentAssistant實(shí)例,然后設(shè)置一些UI屬性,這里主要注意IContentAssistProcessor的實(shí)現(xiàn),我們實(shí)現(xiàn)的內(nèi)容輔助只是針對節(jié)點(diǎn),而且內(nèi)容輔助也是建立在對編輯文檔的分割處理的基礎(chǔ)上.分割處理我們前面已經(jīng)講的夠多了,這里我們就不再做說明

內(nèi)容輔助的UI處理都在ContentAssistant中實(shí)現(xiàn),一般情況下我們不需要子類化,除非當(dāng)前的功能無法滿足我們的要求

內(nèi)容輔助的智能之處主要體現(xiàn)IContentAssistProcessor的實(shí)現(xiàn)上,而一般我們最感興趣的就是ICompletionProposal[] computeCompletionProposals(ITextViewer viewer, int offset);方法,內(nèi)容輔助的提示內(nèi)容列表就是在該方法中提供,這里是我們的代碼實(shí)現(xiàn):

java 代碼
 
  1. public ICompletionProposal[] computeCompletionProposals(ITextViewer viewer, int offset)   
  2. {   
  3.   
  4.     IDocument document = viewer.getDocument();   
  5.     boolean isAttribute = isAttribute(offset, document);   
  6.   
  7.     TextInfo currentText = currentText(document, offset);   
  8.   
  9.     if (!isAttribute)   
  10.     {   
  11.   
  12.         List allElements = dtdTree.getAllElements();   
  13.   
  14.         ICompletionProposal[] result = new ICompletionProposal[allElements.size()];   
  15.         int i = 0;   
  16.         for (Iterator iter = allElements.iterator(); iter.hasNext();)   
  17.         {   
  18.             XMLElement element = (XMLElement) iter.next();   
  19.             String name = element.getName();   
  20.   
  21.             String text = "" + name + ">" + "</" + name + ">";   
  22.             }   
  23.   
  24.             result[i++] = new CompletionProposal(text,    
  25.              currentText.documentOffset,    
  26.              currentText.text.length(),    
  27.              text.length());   
  28.   
  29.         }   
  30.         return result;   
  31.   
  32.     }   
  33.     else  
  34.     {   
  35.   
  36.         List allAttributes = dtdTree.getAllAttributes();   
  37.   
  38.         ICompletionProposal[] result = new ICompletionProposal[allAttributes.size()];   
  39.         int i = 0;   
  40.         for (Iterator iter = allAttributes.iterator(); iter.hasNext();)   
  41.         {   
  42.             String name = (String) iter.next();   
  43.   
  44.             String text = name + "= \"\" ";   
  45.                
  46.             result[i++] = new CompletionProposal(text,    
  47.              currentText.documentOffset,    
  48.              currentText.text.length(),    
  49.              text.length());   
  50.         }   
  51.         return result;   
  52.     }   
  53.   
  54. }   
  55.   

上面的代碼非常的簡單,首先根據(jù)當(dāng)前位置是否為屬性,是則列出已知的所有屬性名,否則列出所有的節(jié)點(diǎn)名.
當(dāng)然這里我們的做法非常簡單,更高級的實(shí)現(xiàn)是對整個文檔進(jìn)行掃描來確定當(dāng)前光標(biāo)在整個文檔結(jié)構(gòu)中所處的位置, 然后使用DTD驗(yàn)證計(jì)算當(dāng)前需要提示的更精確的內(nèi)容列表, 這就需要根據(jù)DTD來理解我們的文檔

總結(jié)
構(gòu)建一個強(qiáng)大的文本編輯器在Eclipse插件開發(fā)中常常會碰到, 而JFace Text Editor是我們展開工作的基礎(chǔ), 它是Eclipse非常強(qiáng)大,非常重要的一套API, 同時也是非常復(fù)雜的一套API.
這里我們從Eclipse PDE提供的XML Editor向?qū)Ю尤胧?通過對其進(jìn)行擴(kuò)展, 演示了高亮顯示, 內(nèi)容格式化, 內(nèi)容大綱, 錯誤標(biāo)記, 內(nèi)容輔助幾個功能的實(shí)現(xiàn), 希望這篇文章對你來實(shí)現(xiàn)自己強(qiáng)大的文本編輯器能有所幫助


安徽新華電腦學(xué)校專業(yè)職業(yè)規(guī)劃師為你提供更多幫助【在線咨詢
主站蜘蛛池模板: 天天综合视频 | 色视频网站在线观看 | 亚洲一区二区中文 | 99视频在线 | 日本福利在线观看 | 综合激情久久 | 成人精品电影 | 中文字幕视频在线免费观看 | 中文字幕综合 | 高清国产午夜精品久久久久久 | 久久久国产精品 | 亚洲国产视频一区 | 亚洲欧美综合 | 精品视频 免费 | 国产精品一区二区在线观看 | 久久精品a一级国产免视看成人 | 欧美视频一级片 | 欧美黄色一区 | 亚洲午夜视频在线观看 | 综合久草 | 精品久久一级片 | 亚洲精品麻豆 | 成人黄视频在线观看 | 色接久久 | 亚洲精品视频在线 | av片在线免费观看 | 国产视频久久 | av观看免费| 亚洲欧美电影 | www一区二区 | 青青草久久网 | 看全黄大色黄大片老人做 | 成人不卡视频 | 国产91在线 | 亚洲 | 欧美色视频在线观看 | 在线日韩视频 | 亚洲视频免费在线观看 | 日韩久久一区二区 | 亚洲精品一区二区三区在线 | 久久成人一区 | 国产一区二区三区在线免费观看 |