在RCP编程中我们经常遇到ViewPart和EditorPart交互的问题,例如:在EditorPart中保存一条记录后,需要刷新对应的ViewPart视图中的数据。
我也是初学RCP编程,在遇到这个问题后我找到了两个解决的办法:
1.给ViewPart增加一个Model对象,利用Observer模式监听Model数据的变化。EditorPart中的数据保存到Model中时将触发监听器刷新ViewPart中的数据。
2.使用Eclipse中的IWorkbenchPart和IWorkbenchPart2接口中的PropertyListener机制。
在ViewPart中打开EditorPart时在EditorPart上注册一个监听:
[code]
tableViewer.addDoubleClickListener(new IDoubleClickListener() {
public void doubleClick(
org.eclipse.jface.viewers.DoubleClickEvent event) {
try {
Contact c = null;
try {
c = (Contact) ((StructuredSelection) event
.getSelection()).getFirstElement();
} catch (Exception e) {
e.printStackTrace();
c = null;
}
IEditorInput input = new ContactEditorInput(c);
IEditorPart editor = getViewSite().getWorkbenchWindow().getActivePage()
.openEditor(input, ContactsEditor.ID);
//在EditorPart上注册监听属性修改
editor.addPropertyListener(new IPropertyListener(){
public void propertyChanged(Object source, int propId) {
if(propId==1111){
System.out.println(source);
System.out.println(propId);
}
}
});
} catch (Throwable e) {
e.printStackTrace();
}
}
});
[/code]
在EditorPart发生变化时,触发事件
[code]
public void doSave(IProgressMonitor monitor) {
MessageDialog.openInformation(this.getSite().getShell(), "Save",
"Contact saved.");
setDirty(false);
//触发修改事件
firePropertyChange(1111);
}
[/code]
小结:
第一种方式是标准的Observer模式,可以适应于多种情况下,而不限于ViewPart和EditorPart交互,但是代码量稍微多一点。
第二种方式使用的分别是IWorkbench2.firePropertyChange和IWorkbench.addPropertyListener方法,只能用于部分Eclipse的组件中,但使用简单。
我奇怪的是Eclipse的TableView没有一个类似Swing中的DefaultTableModel的模型类。如果有缺省的Observer实现,TableView的使用会更方便一些。
另外,由于我不了解Eclipse中资源事件机制,我还尝试过使用IResourceChangeListener来监听资源的修改事件。但我没有成功,网上这方面的资源不多,http://www.eclipse.org/articles/Article-Resource-deltas/resource-deltas.html
这篇文章对Eclipse中的资源事件机制作了较详细的介绍。
我也是初学RCP编程,在遇到这个问题后我找到了两个解决的办法:
1.给ViewPart增加一个Model对象,利用Observer模式监听Model数据的变化。EditorPart中的数据保存到Model中时将触发监听器刷新ViewPart中的数据。
2.使用Eclipse中的IWorkbenchPart和IWorkbenchPart2接口中的PropertyListener机制。
在ViewPart中打开EditorPart时在EditorPart上注册一个监听:
[code]
tableViewer.addDoubleClickListener(new IDoubleClickListener() {
public void doubleClick(
org.eclipse.jface.viewers.DoubleClickEvent event) {
try {
Contact c = null;
try {
c = (Contact) ((StructuredSelection) event
.getSelection()).getFirstElement();
} catch (Exception e) {
e.printStackTrace();
c = null;
}
IEditorInput input = new ContactEditorInput(c);
IEditorPart editor = getViewSite().getWorkbenchWindow().getActivePage()
.openEditor(input, ContactsEditor.ID);
//在EditorPart上注册监听属性修改
editor.addPropertyListener(new IPropertyListener(){
public void propertyChanged(Object source, int propId) {
if(propId==1111){
System.out.println(source);
System.out.println(propId);
}
}
});
} catch (Throwable e) {
e.printStackTrace();
}
}
});
[/code]
在EditorPart发生变化时,触发事件
[code]
public void doSave(IProgressMonitor monitor) {
MessageDialog.openInformation(this.getSite().getShell(), "Save",
"Contact saved.");
setDirty(false);
//触发修改事件
firePropertyChange(1111);
}
[/code]
小结:
第一种方式是标准的Observer模式,可以适应于多种情况下,而不限于ViewPart和EditorPart交互,但是代码量稍微多一点。
第二种方式使用的分别是IWorkbench2.firePropertyChange和IWorkbench.addPropertyListener方法,只能用于部分Eclipse的组件中,但使用简单。
我奇怪的是Eclipse的TableView没有一个类似Swing中的DefaultTableModel的模型类。如果有缺省的Observer实现,TableView的使用会更方便一些。
另外,由于我不了解Eclipse中资源事件机制,我还尝试过使用IResourceChangeListener来监听资源的修改事件。但我没有成功,网上这方面的资源不多,http://www.eclipse.org/articles/Article-Resource-deltas/resource-deltas.html
这篇文章对Eclipse中的资源事件机制作了较详细的介绍。