让多个Viewer对应一个属性视图

简介:

为了让用户在WorkbenchPart(如IEditorPart)的Viewer(如TableViewer)里选择一个对象时,属性视图里能显示这个元素的属性,一般会将这个Viewer设置为该WorkbenchPart的site的selectionProvider:

editPart.getSite().setSelectionProvider(theViewer);

但如果是一个WorkbenchPart里有多个Viewer的情况呢?我们可以实现为当用户在任意一个Viewer里选择了一个对象后,属性视图里显示这个对象的属性。为此,根据黄老大的提示,需要写一个CompositeSelectionProvider,它实现ISelectionChangedListener以监听每个Viewer的选择事件,同时它要实现ISelectionProvider,因为我们要把它设置为该site的selectionProvider:

class  CompositeSelectionProvider  implements  ISelectionProvider, ISelectionChangedListener {
    ISelection selection;

    List listeners 
=   new  ArrayList();

    
public   void  addSelectionChangedListener(ISelectionChangedListener listener) {
        listeners.add(listener);
    }

    
public  ISelection getSelection() {
        
return  selection;
    }

    
public   void  removeSelectionChangedListener(ISelectionChangedListener listener) {
        listeners.remove(listener);
    }

    
public   void  setSelection(ISelection selection) {
        
this .selection  =  selection;
        
final  SelectionChangedEvent e  =   new  SelectionChangedEvent( this , selection);
        Object[] listenersArray 
=  listeners.toArray();

        
for  ( int  i  =   0 ; i  <  listenersArray.length; i ++ ) {
            
final  ISelectionChangedListener l  =  (ISelectionChangedListener) listenersArray[i];
            Platform.run(
new  SafeRunnable() {
                
public   void  run() {
                    l.selectionChanged(e);
                }
            });
        }
    }

    /*****************************************************************
    ************** ISelectionChangedListener implementation **********
    **********************************************************
******** /
    
public   void  selectionChanged(SelectionChangedEvent event) {
        setSelection(event.getSelection());

    }

}

在WorkbenchPart#createPartControl()方法里让这个CompositeSelectionProvider监听每个viewer的选择事件,并把它设置为site的selectionProvider,代码如下:

// The composite selectionProvider instance
CompositeSelectionProvider compositeSelectionProvider = new  CompositeSelectionProvider();

public   void  createPartControl(Composite parent) {
    
//
    viewer1.addSelectionChangedListener(compositeSelectionProvider);
    viewer2.addSelectionChangedListener(compositeSelectionProvider);
    
//
    getSite().setSelectionProvider(compositeSelectionProvider);
}

 

 注:在这篇教程里也有类似的解决方法,见“Multiple Selection Providers Within a Part”一节。

本文转自博客园八进制的博客,原文链接:让多个Viewer对应一个属性视图,如需转载请自行联系原博主。

相关文章
Element-ui 表格(Table)组件中鼠标悬停(hover)样式修改
Element-ui 表格(Table)组件中鼠标悬停(hover)样式修改
3083 0
Cesium 获取当前视图范围
Cesium作为一个开源的WebGlobe解决方案已经很牛了,不过因为开发的资料不多,很多功能不知道怎么实现。下面记录下自己获取Cesium当前场景范围的方法(2维中对应的是extent)。   extent其实对我们有用的也就是左上角和右下角坐标,于是首先应该想办法实现的是获取场景左上角和右下角的经纬度坐标。
1593 0
|
5月前
|
JavaScript 前端开发 Shell
Element-ui Table表格导出功能的实现
Element-ui Table表格导出功能的实现
92 0
|
8月前
|
设计模式 开发框架 算法
【QML 创建界面】QML界面的动态创建及其其他方法 (Dynamic Creation of QML Interfaces and Other Methods)
【QML 创建界面】QML界面的动态创建及其其他方法 (Dynamic Creation of QML Interfaces and Other Methods)
878 0
|
前端开发 JavaScript 容器
Bootstrap 表格样式-状态类-Table
Bootstrap 表格样式-状态类-Table
62 0
|
Web App开发 前端开发 iOS开发
Element-ui中 表格 (Table)组件中滚动条样式修改
Element-ui中 表格 (Table)组件中滚动条样式修改
1442 0
Element-ui中 表格 (Table)组件中滚动条样式修改
|
SQL 数据处理
视图的创建
如何创建和使用视图的功能,更好的方便我们的工作。
122 0
|
缓存 JavaScript 前端开发
使用Render 自定义列的表格组件——Table
使用Render 自定义列的表格组件——Table
685 1
cesium根据id选中实体
cesium根据id选中实体
622 0
|
JavaScript 数据库
EasyUI_datagrid实现动态加载列并为其绑定数据
EasyUI_datagrid实现动态加载列并为其绑定数据
698 0