// 下階層用テンプレート
#topicpath
----
//ここにコンテンツを記述します。


すでに他のプラグイン開発者から提供されているビュー(IViewPartの実装クラスね)内に配置されているウィジェットのポップアップメニューにアクションを追加したり、そのビュー自体のメニューバーにアクションを追加したいときには、このクラスを使用します。

-ビュー自体のメニューバーにアクションを追加
#ref(pic2.png)

~

-ビュー内のウィジェット(例はTableViewer)のポップアップメニューにアクションを追加
#ref(pic1.png)


#contents


**ビュー自体のメニューバーにアクションを追加する。 [#w2f87472]

***拡張ポイント [#m903914d]
 org.eclipse.ui.viewActions

***plugin.xmlのサンプル [#n5a5e1b3]
 <extension point="org.eclipse.ui.viewActions">
  <viewContribution
    id="nu.mine.kino.plugin.samples.rcp.viewContribution2"
    targetID="nu.mine.kino.plugin.samples.rcp.view3">
   <action
       class="nu.mine.kino.plugin.samples.rcp.ViewActionDelegate2"
       id="nu.mine.kino.plugin.samples.rcp.action2"
       label="アクション3" menubarPath="addition"
       style="push"/>
  </viewContribution>
 </extension>

~

引き続き、ビュー内のViewerクラスのポップアップメニューにアクションを追加する方法です。 


**ビュー内のViewerクラスのポップアップメニューにアクションを追加する。 [#r1b0d2a7]
***拡張ポイント [#b2c43867]
 org.eclipse.ui.popupMenus

***その前に [#ef888ced]
他のビュー内のViewerのポップアップメニューにアクションを追加するにはビュー側で「そのViewerが使っているポップアップメニューを公開してくれている」ことが前提となっています。具体的には
  getSite().registerContextMenu(menuMgr, getSite().getSelectionProvider());
を使ってビューがメニューを公開してくれているか、ということです。

通常ビューを作るときは以下のようなサンプルになると思います。


 public void createPartControl(Composite parent) {
   viewer = new TableViewer(parent, SWT.MULTI | SWT.H_SCROLL
       | SWT.V_SCROLL);
   ...
   makeActions(); <- フィールドのアクションをnewする
   hookContextMenu();
   hookDoubleClickAction();
   contributeToActionBars();
 }


 private void hookContextMenu() {
   MenuManager menuMgr = new MenuManager("#PopupMenu");
   menuMgr.setRemoveAllWhenShown(true);
   menuMgr.addMenuListener(new IMenuListener() {
     public void menuAboutToShow(IMenuManager manager) {
       fillContextMenu(manager);
     }
   });
   Menu menu = menuMgr.createContextMenu(viewer.getControl());
   viewer.getControl().setMenu(menu);
   
   getSite().registerContextMenu(menuMgr, viewer); <-これ。
 }


 private void fillContextMenu(IMenuManager manager) {
   manager.add(action1);
   manager.add(action2);
   // Other plug-ins can contribute there actions here
   manager.add(new Separator(IWorkbenchActionConstants.MB_ADDITIONS)); <-これ。
 }

こうやっておけば外部からアクションを追加することができます。

***ポイント [#a6554dfb]
ポイントは
-そのビュー用のメニューマネージャを作る
 MenuManager menuMgr = new MenuManager("#PopupMenu");

-メニューマネージャを使って(ビュー内の)viewerにコンテキストメニューを作る
 Menu menu = menuMgr.createContextMenu(viewer.getControl());
 viewer.getControl().setMenu(menu);

-そのビューのメニューマネージャを外部に公開する((第二引数のビューワはメニューの公開だけだったら、適当でいいっぽい??このビューのselectionProviderを引数に渡すみたいなんだけど。。))((また、ビューのメニューバーに登録するだけだったら、このメソッドはいらない))
 getSite().registerContextMenu(menuMgr, viewer);

-メニューの追加させたい場所に
 manager.add(new Separator(IWorkbenchActionConstants.MB_ADDITIONS));
でキー値を設定しておく

ですね。

***plugin.xml のサンプル [#j583f5eb]


 getSite().registerContextMenu(menuMgr, viewer);
 manager.add(new Separator(IWorkbenchActionConstants.MB_ADDITIONS));
としたことで、
-このビューのポップアップはmenuMgrですよ
-ポップアップにアクションを追加するときにplugin.xmlに指定するキー値(targetID)はビューのIDですよ((もしくはgetSite().registerContextMenu("hogeID",menuMgr, viewer);とやってある場合は、hogeIDがキー値。))
-plugin.xmlのmenubarPathはIWorkbenchActionConstants.MB_ADDITIONSという文字列(("additions"という文字列))ですよ

という事になります。ここまでできてると別のプラグインからこのビューのポップアップにアクションを追加することができます。追加するにはplugin.xmlで以下のように宣言すればOKです。
 <extension point="org.eclipse.ui.popupMenus">
   <viewerContribution
      id="nu.mine.kino.plugin.samples.rcp.viewerContribution1"
      targetID="nu.mine.kino.plugin.samples.rcp.view3">
     <action
       class="nu.mine.kino.plugin.samples.rcp.Action1"
       ↑ IViewActionDelegateの実装クラス
       id="nu.mine.kino.plugin.samples.rcp.action1"
       label="アクション4"
       menubarPath="additions"/>
       ↑ additionsは IWorkbenchActionConstants.MB_ADDITIONSの文字列
   </viewerContribution>
 </extension>













----
この記事は
#vote(おもしろかった,そうでもない)

#comment
#topicpath


SIZE(10){現在のアクセス:&counter;}

トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS