国产精品一区二区精品_久久小视频_天堂va在线观看_99久久夜色精品国产亚洲96_日本手机在线视频_av成人免费

當前位置:首頁 > 網站舊欄目 > 學習園地 > 設計軟件教程 > Command Framework如何實現EMF Model的編輯

Command Framework如何實現EMF Model的編輯
2010-01-14 22:47:19  作者:  來源:
源于《EMF.Edit Framework Programmgering's Guide》

EMF.Edit里面有幾個類比較繞,很容易被搞得暈頭轉向,所以需要澄清以下:
★AdapterFactoryContentProvider, ItemProviderAdapterFactory和ItemProviderAdapter之間的關系,ItemProviderAdapterFactory用來創建各種Adapter以及將各種notifier跟這些adapter關聯起來,AdapterFactoryContentProvider包裝了一個ItemProviderAdapterFactory(AdapterFactory),它用來將JFace需要的content provider代理到item content provider上,對content provider各種方法的調用將調用到相應的item content provider上,對org.eclipse.jface.viewers.IStructuredContentProvider的調用將代理到IStructuredItemContentProvider上,對ITreeContentProvider的調用將代理到ITreeItemContentProvider上,而對IPropertySourceProvider的調用將代理到IItemPropertySource,而ItemProviderAdapter是所有ItemProvider的基類,AdapterFactoryLabelProvider和ItemProviderAdapter之間也存在類似的關系

★為了顯示model內容,我們需要使用content provider和label provider,而編輯model內容則需要使用到editing domain,AdapterFactoryEditingDomain是一個和AdapterFactoryContentProvider、AdapterFactoryLabelProvider類似的東東

★editing domain主要有兩個功能:一個是作為command的factory(所以它的實現類是AdapterFactoryEditingDomain);另一個對EMF Model(ResourceSet,因此提供了getResource()方法)進行管理

★EditingDomain,AdapterFactoryEditingDomain,EditingDomainItemProvider和Command之間的關系,AdapterFactoryEditingDomain實現了EditingDomain接口,AdapterFactoryEditingDomain和AdapterFactoryContentProvider一樣,也是用來將EditingDomain的方法代理到EditingDomainItemProvider上去。

從一般的操作說起,比如從一個company對象上刪除一個department對象,通常我們的做法是:
 
java 代碼
  1. Department d = ...  
  2.   Company c = ...  
  3.   c.getDepartments().remove(d);  

但是如果是使用command,則會這樣做:
 
java 代碼
 
  1. Department d = ...  
  2.   Company c = ...  
  3.   EditingDomain ed = ...  
  4.   RemoveCommand cmd =  
  5.     new RemoveCommand(ed, c, CompanyPackage.eINSTANCE.getCompany_Departments(), d);  
  6.   ed.getCommandStack().execute(cmd);  

不過這個做法有一個問題,就是不是很通用,因為所有的刪除操作基本上都差不多,所以還需要繼續抽象,這時就必須引入EditingDomain.
EditingDomain的接口定義如下:
java 代碼
 
  1. public interface EditingDomain  
  2.   {  
  3.     ...  
  4.     Command createCommand(Class commandClass, CommandParameter commandParameter);  
  5.     ...  
  6.   }  

為了創建一個Command對象,我們需要構造一個CommandParameter對象。在createCommand方法里面會調用指定的Command的靜態create方法來創建指定的Command對象,通過使用create方法,我們可以對上面的操作做進一步的改寫:
java 代碼
  1. Department d = ...  
  2. EditingDomain ed = ...  
  3. Command cmd = RemoveCommand.create(ed, d);  
  4. ed.getCommandStack().execute(cmd);  

通過上面的改寫,差不多實現了一個通用的刪除操作流程
接下來我們可以看看一個command的創建過程,首先是調用指定command的靜態create方法,該方法將調用EditingDomain的createCommand方法,AdapterFactoryEditingDomain作為EditingDomain的實現類,又將command的創建過程代理到EditingDomainItemProvider上,在Itemprovider(實現了EditingDomainItemProvider接口)中,最終使用new創建指定的Command實例
我們可以采用多種方式對command定制,第一種就是復寫generated的EditingDomainItemProvider實現類的createCommand方法:
java 代碼
 
  1. public class CompanyItemProvider ...  
  2. {  
  3.   ...  
  4.   
  5.   public Command createCommand(final Object object, ...)  
  6.   {  
  7.     if (commandClass == RemoveCommand.class)  
  8.     {  
  9.       return new RemoveDepartmentCommand(...);  
  10.     }  
  11.     return super.createCommand(...);  
  12.   }  
  13. }  

這里的RemoveDepartmentCommand 就是我們自己實現的刪除操作。
第二種方式就是復寫createRemoveCommand()來實現定制:
java 代碼
 
  1. protected Command createRemoveCommand(...)  
  2.   {  
  3.     return new RemoveDepartmentCommand(...);  
  4.   }  


通知的處理
在創建AdapterFactoryContentProvider的時候會將其作為一個listener注冊到AdapterFactory里面,這個AdapterFactory實現了IChangeNotifier接口,而AdapterFactory在創建每一個ItemProvider的時候又會把自己傳遞過去,從而使得AdapterFactory成為model的消息分發中心,在AdapterFactoryContentProvider又會記錄所有需要接受通知的viewer(也就是為其提供了content provider的viewer)。
當model被改變之后,將觸發和該model相關的adapter的notifyChanged()方法(這里面的adapter就包括itemprovider),當然這里還有一個過濾的過程,只把那些跟viewer相關的notification才會發送給viewer。為了將notification繼續傳遞,會使用ViewerNotification這樣一個對象來對notifation以及其他的信息進行封裝,因此它繼承了Notification,除了Notification相關的信息之外,還封裝了要更新的viewer的相關元素,IViewerNotification 的定義如下:
 
java 代碼
 
  1. public interface IViewerNotification extends Notification  
  2.   {  
  3.     Object getElement();  
  4.     boolean isContentRefresh();  
  5.     boolean isLabelUpdate();  
  6.   }  

對于消息的傳遞還會進行分類,這個是在notifyChanged這個方法里面做的,如下面的代碼:
java 代碼
 
  1. public void notifyChanged(Notification notification)  
  2.   {  
  3.     ...  
  4.     switch (notification.getFeatureID(Company.class))  
  5.     {  
  6.       case CompanyPackage.COMPANY__NAME:  
  7.     //ViewerNotification(Notification decoratedNotification, Object element,
  8. boolean contentRefresh, boolean labelUpdate)  
  9.         fireNotifyChanged(new ViewerNotification(notification, ..., falsetrue));  
  10.         return;  
  11.       case CompanyPackage.COMPANY__DEPARTMENT:  
  12.         fireNotifyChanged(new ViewerNotification(notification, ..., truefalse));  
  13.         return;  
  14.     }  
  15.     super.notifyChanged(notification);  
  16.   }  

可以看出,如果是attribute,那么會對label進行更新,如果是reference,那么需要更新content了,否則什么都不做。fireNotifyChanged方法是在ItemProviderAdapter(就是所有ItemProvider的基類)里面定義的,它會把notifaction傳給adapter factory,前面我們說過adapter factory是notification的分發器,因此它會將notification發送給所有注冊的listener,我們前面也說過AdapterFactory實現IChangeNotifier接口,并作為listener注冊到adapter factory中去了,因此在最后會調用adapter factory的fireNotifyChanged方法,當然了adapter factory也會將notification代理別的對象(可能是tree或者table的content/label provider,當然在emf中就是itemprovider了)上去,最后viewer被更新了。
 

安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢
国产精品一区二区精品_久久小视频_天堂va在线观看_99久久夜色精品国产亚洲96_日本手机在线视频_av成人免费
<button id="0mgmq"><pre id="0mgmq"></pre></button>
  • <tr id="0mgmq"></tr>
  • <abbr id="0mgmq"><source id="0mgmq"></source></abbr> <button id="0mgmq"></button>
  • 欧美日韩亚洲在线| 精品一区在线播放| 一级做a爰片久久| 国产精品免费观看高清| 亚洲精品1区2区| 亚洲综合第一| 水蜜桃一区二区三区| 国产丝袜不卡| 看欧美日韩国产| 亚洲色图自拍| 日韩亚洲不卡在线| 亚洲欧洲一区| 亚洲国产欧洲综合997久久| 女人色偷偷aa久久天堂 | 狠狠色综合网| 欧美色一级片| 欧美系列一区| 好吊一区二区三区| 欧美国产先锋| 国产精品对白刺激久久久| 中文视频一区视频二区视频三区| 日本一区二区不卡高清更新| 精品一区二区三区日本| 5566av亚洲| av一区二区三区在线观看| αv一区二区三区| 国产精品免费一区二区三区观看| 粉嫩av四季av绯色av第一区| aaa级精品久久久国产片| 春色成人在线视频| 精品久久久久久亚洲| 久久国产手机看片| 欧美理论一区二区| 亚洲成人第一| 欧美精品aa| 国产欧美在线| av一区观看| 欧美日韩在线一二三| 在线精品亚洲一区二区| 国产精品红桃| 亚洲一区二区三区高清不卡| 巨乳诱惑日韩免费av| 久久www免费人成精品| 亚洲欧洲一区二区在线观看| 一区二区在线不卡| 在线亚洲国产精品网站| 97超级碰碰| 色999五月色| 在线日韩中文| 懂色中文一区二区三区在线视频| 久久精品成人一区二区三区蜜臀| 午夜精品一区二区三区在线观看| 黄色另类av| **亚洲第一综合导航网站| 国产亚洲自拍偷拍| 中文网丁香综合网| 美女被久久久| 亚洲第一导航| 久久青青草综合| 性欧美.com| 国产精品免费在线| 日韩高清在线播放| 国产一区二区高清视频| 欧美日韩成人一区二区三区| 欧美三区不卡| 精品中文字幕一区| 亚洲久久视频| 欧美亚洲一级二级| 亚洲丰满在线| 日本精品一区二区| 一级日韩一区在线观看| 鲁鲁狠狠狠7777一区二区| 国产精品v日韩精品v欧美精品网站| 久久久99爱| 欧美色一级片| 久久免费一区| 久久另类ts人妖一区二区| 在线电影看在线一区二区三区| 久久成人精品| 欧美日韩精品一区| 欧美久久久久久| 老牛影视一区二区三区| 国内精品**久久毛片app| 国产精品一区视频| 国产视频一区三区| 亚洲午夜在线观看| 国产精品香蕉视屏| 亚洲综合日本| 亚洲午夜av| 亚洲精品人成| 欧美成人在线免费观看| 麻豆精品91| 一区二区三区四区五区在线| 在线视频不卡一区二区| 久久久久久九九九九| 久久本道综合色狠狠五月| 好看不卡的中文字幕| 亚洲最大色综合成人av| 欧美黑人3p| 国产在线一区二| 2020国产精品久久精品不卡| 日韩网站在线| 最新亚洲激情| 国产精品国产三级欧美二区| 亚洲欧美日韩在线综合 | 欧美日韩综合网| 久久久久久穴| 亚洲欧美日韩视频二区| 夜夜嗨网站十八久久 | 亚洲一区观看| 在线日韩av| 亚洲精品1区2区| 激情久久中文字幕| 国产综合婷婷| 黄色工厂这里只有精品| 欧美福利一区二区三区| 亚洲国产精品视频一区| 天天综合色天天综合色hd| 麻豆蜜桃91| 热re99久久精品国产99热| 九色视频成人porny| 九色综合日本| 欧美性xxxx69| 亚洲电影一二三区| 一个色的综合| 黄色一区二区三区四区| 在线日韩av| 国产精品久久久亚洲一区| 亚洲在线不卡| 国产精品一区二区三区四区五区 | 在线国产精品网| 国产一区二区中文| 99视频精品| 3d动漫啪啪精品一区二区免费 | 亚洲综合另类| 国产成人女人毛片视频在线| 精品久久久久亚洲| 亚洲欧美影院| 在线观看视频免费一区二区三区| 亚洲另类视频| av在线不卡观看| 视频一区不卡| 亚洲第一黄网| av在线不卡观看| 日韩经典在线视频| 国产综合自拍| av色综合网| 亚洲成人在线视频网站| 亚洲三级电影在线观看| 91一区二区三区| 色乱码一区二区三在线看| 亚洲午夜激情| 久久一区精品| 日韩精品国内| 国产欧美精品久久| 精品乱码一区二区三区| 亚洲一区二区在线看| 亚洲国内自拍| 精品视频一区在线| 亚洲视频日本| 国产一区二区三区奇米久涩| 亚洲图片都市激情| 免费日韩一区二区| 日韩欧美在线电影| 亚洲欧美大片| 亚洲欧洲另类精品久久综合| 国产农村妇女精品一二区| 日本一区高清在线视频| 好看的日韩av电影| 精品无码久久久久国产| 欧美天堂亚洲电影院在线观看| 51国产成人精品午夜福中文下载| 色综合影院在线观看| 久久精品五月| 欧美日韩一区二区三区免费| av一区二区三区四区电影| 欧美久久一区| 国产一区二区视频在线免费观看| 国产精品激情电影| 欧美激情www| 国产亚洲毛片在线| 亚洲国产精品视频一区| av一区二区三区在线观看| 欧美午夜精品久久久久免费视| 国产女人水真多18毛片18精品| 国内在线观看一区二区三区| 欧美久久久久久一卡四| 久久久精品动漫| 国产在线欧美| 日本在线高清视频一区| 91丝袜脚交足在线播放| 激情久久婷婷| 亚洲.欧美.日本.国产综合在线| 高清一区二区三区视频| 亚洲激情av| 欧美日本免费| 亚洲国产精品一区二区第一页| 国产日韩精品久久| 亚洲欧美日韩综合国产aⅴ| 国产精品国产亚洲精品看不卡15|