亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区

當前位置:首頁 > 網站舊欄目 > 學習園地 > 設計軟件教程 > 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被更新了。
 

安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢
亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区
秋霞久久久久久一区二区| 91精品国产综合久久久久久蜜臀| 一本色道久久综合亚洲精品婷婷| 欧美大成色www永久网站婷| 国产精品久久久久久久一区探花| 国产成人看片| 国产v综合v亚洲欧美久久| 7777在线视频| 久久免费成人精品视频| 久久免费福利视频| 爽爽爽爽爽爽爽成人免费观看| 色偷偷av亚洲男人的天堂| 久久久久久香蕉网| 国产高清av在线播放| 日韩亚洲精品视频| 精品国产一区二区三区久久久 | 久久国产色av免费观看| 色婷婷成人综合| 国产精品入口尤物| 欧美成人中文字幕在线| 亚洲一区二区三区四区视频 | 日本三级久久久| 欧美日韩一区二区在线免费观看| 黄色一级一级片| 高清欧美精品xxxxx| 国产成人91久久精品| 久久人人爽人人爽人人片亚洲| 两个人的视频www国产精品| 一区二区高清视频| 日本wwwcom| 国产美女高潮久久白浆| 久久青青草原| 久久久久久久av| 久久综合网hezyo| 亚洲欧洲三级| 欧美亚洲一区在线| 国产一区视频在线播放| 91精品免费视频| 国产精品久久久久久久天堂 | 国产在线视频欧美| 国产精品永久入口久久久| 久久综合亚洲精品| 国产精品久久久久久av| 亚洲国产一区二区在线| 激情五月婷婷六月| 7777免费精品视频| 成人97在线观看视频| 日韩精品免费一区| 99在线免费观看视频| 久久99久久精品国产| 欧美日韩福利在线观看| 欧美在线视频网| 91精品国产自产91精品| 欧美精品手机在线| 日本www高清视频| 99亚洲精品视频| 国产精品狠色婷| 日本视频一区在线观看| 国产精品有限公司| 国产精品三级久久久久久电影| 视频一区二区精品| 国产精品一色哟哟| 国产精品久久77777| 欧美做受777cos| 国产精品一区而去| 国产精品久久久久久亚洲调教| 日本午夜精品一区二区三区| www.av一区视频| 国产aⅴ夜夜欢一区二区三区| 日韩亚洲欧美精品| 国产成人在线视频| 亚洲精蜜桃久在线| 国产精品一区在线观看| 国产免费一区二区视频| 国产精品视频yy9099| 欧洲日本亚洲国产区| 国产成人精品日本亚洲11| 亚洲一区二区三区av无码| 成人精品视频一区二区| 国产精品裸体一区二区三区| 日韩精品av一区二区三区| 久久这里只有精品18| 亚洲精品中字| av片在线免费| 一级一片免费播放| 99热成人精品热久久66| 欧美精品国产精品日韩精品| 国产免费色视频| 精品久久一二三| 国产欧美精品aaaaaa片| 欧美巨大黑人极品精男| 国产日韩在线看| 欧美激情视频在线观看| 国产精品自拍合集| 欧美大肥婆大肥bbbbb| 国产视色精品亚洲一区二区| 精品成在人线av无码免费看| 国产乱子伦农村叉叉叉| 伊人婷婷久久| 91av在线精品| 日本欧美中文字幕| 日韩视频一区在线| 欧美日韩一区二区视频在线观看 | 成人久久久久久久| 亚洲一卡二卡| 久在线观看视频| 日韩精品福利片午夜免费观看| 久久精品91久久久久久再现| 蜜臀av.com| 亚洲欧洲久久| 久久久久久中文| 免费亚洲一区二区| 亚洲综合日韩在线| 国产高清精品在线观看| 欧美自拍视频在线观看| 久久综合色88| 99视频免费观看蜜桃视频| 亚洲 日韩 国产第一区| 色婷婷av一区二区三区久久| 国产亚洲精品自在久久| 亚洲a∨日韩av高清在线观看| 国产成人精品999| 韩国一区二区av| 亚洲在线不卡| www.日韩视频| 国产免费一区二区视频| 色大师av一区二区三区| 久久综合伊人77777尤物| 国产九色porny| 日韩成人在线资源| 国产精品高清在线观看| 99久久精品久久久久久ai换脸| 日韩av第一页| 欧美精品一二区| 国产成人在线一区| 国产区日韩欧美| 日韩免费高清在线观看| 国产aaa精品| 日韩在线视频免费观看| 国产精品在线看| 欧日韩一区二区三区| 亚洲一区二区三区四区视频 | 精品视频一区二区| 懂色中文一区二区三区在线视频| 精品国内亚洲在观看18黄| 国产精品一区二区三区不卡| 日韩精品无码一区二区三区免费| 欧美激情国产精品| 久久久国产视频91| 91久久久久久久久久久| 精品午夜一区二区| 日本阿v视频在线观看| 一区国产精品| 国产精品久久久| www.日韩.com| 久久欧美在线电影| 成人精品视频99在线观看免费| 激情五月五月婷婷| 日本精品一区二区 | 国产精品久久久久9999小说| 久久www免费人成精品| 国产裸体写真av一区二区| 欧美日韩成人一区二区三区| 日韩中文字幕av在线| 欧美激情精品久久久久久大尺度| 久久精品视频免费播放| 久久99精品久久久久久水蜜桃| 91精品视频在线播放| 国产精品在线看| 国产午夜福利在线播放| 欧美成人一区二区在线观看| 日本不卡久久| 午夜精品视频在线| 亚洲欧洲国产精品久久| 亚洲午夜久久久影院伊人| 不卡av在线播放| 麻豆国产精品va在线观看不卡 | 久久久久北条麻妃免费看| 国产不卡在线观看| 777精品久无码人妻蜜桃| av资源站久久亚洲| 福利在线一区二区| 国产欧美日韩综合精品| 国内精品国语自产拍在线观看| 青草热久免费精品视频| 日韩精品一区二区三区四区五区| 日韩亚洲欧美精品| 日韩精品一区在线视频| 色综合久久av| 日韩视频在线免费看| 日本欧美视频在线观看| 日韩视频一二三| 茄子视频成人免费观看| 欧美日韩国产综合在线| 韩国三级日本三级少妇99| 国内精品久久影院| 国产日韩欧美成人| 国产九区一区在线| 97久久精品人搡人人玩| 国产精品9999|