- 追加された行はこの色です。
- 削除された行はこの色です。
// 下階層用テンプレート
#topicpath
----
//ここにコンテンツを記述します。
すでに他のプラグイン開発者から提供されているビュー(IViewPartの実装クラスね)内のウィジェットのポップアップメニューにアクションを追加したり、そのビュー自体のメニューバーにアクションを追加したいときには、このクラスを使用します。
すでに他のプラグイン開発者から提供されているビュー(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); <-これ。
}
***拡張ポイント [#y5ec4cb0]
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;}