JFace Viewer

组成:1)模型和元素,模型为元素的集合;2)内容提供者与标签提供者;3)控件 ;4)查看器(负责协调前面三个部分)。
模型维护的是元素集合,需要自己开发,当模型内容改变时应向外界发出一个"属性改变"的事件。

通过内容提供器对模型解析,所有内容提供者都实现IContentProvider接口,对于具体的子类,又有子接口,如列表和表格查看器实现 IStructuredContentProvider,树查看器实现ITreeContentProvider。内容提供器的另一个工作是监听模型的变化,并操作查看器将变化反映在界面上。

LabelProvider负责每个元素如何在界面显示,需要实现IBaseLabelProvider,表格查看器要实现 ITableLabelProvider。其中的isLabelProperty(object element ,String property)指定property属性是否会用于显示,在更新元素时,查看器会调用这个方法,若元素的变化不影响显示,则没有必要更新

要实现对模型的监听,需要将模型模拟成一个事件源,将内容提供方模拟成一个监听器。协调关系如图:

[img]http://dl.iteye.com/upload/attachment/157229/5d703693-2940-3ec2-a983-9cf486e95638.jpg[/img]


下面给个例子,代码来自《eclipse学习笔记》:

User:为元素,是自定义的Java类

public class ListModel {

public static final String ADD_ELEMENT = "addElement";
public static final String REMOVE_ELEMENT = "removeElement";
private PropertyChangeSupport delegate;
private Vector content;
public ListModel() {
content = new Vector();
delegate = new PropertyChangeSupport(this);
}

//模拟事件源

public void addPropertyChangeListener(PropertyChangeListener listener) {
delegate.addPropertyChangeListener(listener);
}

public void firePropertyChange(PropertyChangeEvent evt) {
delegate.firePropertyChange(evt);
}

public void removePropertyChangeListener(PropertyChangeListener listener) {
delegate.removePropertyChangeListener(listener);
}

//触发属性改变事件

public void add(Object element) {
if (content.add((User) element))
firePropertyChange(new PropertyChangeEvent(this, ADD_ELEMENT, null,
element));
}

//触发属性改变事件
public void remove(Object element) {
if (content.remove(element))
firePropertyChange(new PropertyChangeEvent(this, REMOVE_ELEMENT,
null, element));
}

public Object[] elements() {
return content.toArray();
}
}


public class ListContentProvider implements IStructuredContentProvider,PropertyChangeListener{
private ListViewer viewer;
private ListModel model;

//返回元素集合
@Override
public Object[] getElements(Object inputElement) {
return model.elements();
}

@Override
public void dispose() {
}

//设置输入模型,注册监听器开始对新模型监听

@Override
public void inputChanged(Viewer viewer, Object oldInput, Object newInput) {
this.viewer = (ListViewer) viewer;
if (oldInput instanceof ListModel)
((ListModel) oldInput).removePropertyChangeListener(this);
if (newInput instanceof ListModel) {
this.model = (ListModel) newInput;
((ListModel) newInput).addPropertyChangeListener(this);
}
}

//响应属性改变事件

@Override
public void propertyChange(PropertyChangeEvent evt) {
if (ListModel.ADD_ELEMENT.equals(evt.getPropertyName()))
viewer.add(evt.getNewValue());
if (ListModel.REMOVE_ELEMENT.equals(evt.getPropertyName()))
viewer.remove(evt.getNewValue());
}
}


public class ListLabelProvider implements ILabelProvider{
@Override
public Image getImage(Object element) {
return null;
}

@Override
public String getText(Object element) {
if(element instanceof User)
return ((User)element).getName();
return element.toString();
}
}

//使用
public static void main(String[] args) {
Display display = Display.getDefault();
Shell shell = new Shell(display);
shell.setSize(400, 400);
shell.setLayout(new FillLayout());

ListViewer viewer = new ListViewer(shell, SWT.BORDER);

viewer.setContentProvider(new ListContentProvider());
viewer.setLabelProvider(new ListLabelProvider());
ListModel input = new ListModel();
viewer.setInput(input);

shell.open();
shell.layout();
//只需要操作模型就能改变视图,实现界面与模型完全分离
input.add(new User("1","张三"));
input.add(new User("2","李四"));
input.add(new User("3","王五"));

while (!shell.isDisposed())
if (!display.readAndDispatch())
display.sleep();
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值