JFace中MVC的表格使用介绍

一、使用流程

当在Jface中使用MVC模式来展示表格时,通常会遵循以下步骤:

1、创建数据模型:

  • 创建一个数据模型实体类用来表示表格中的每一行数据。
  • 创建表格的内容提供器和标签提供器,其中内容提供器实现接口IStructuredContentProvider;标签提供器实现接口ITableLabelProvider,分别负责提供表格中的每个单元格的图像和文本以及整个表的数据。

2、创建表格:

  • 使用TableViewer类创建表格。
  • 设置表格的布局参数,包括样式和布局数据。
  • 创建表格列,并设置每列的标签提供器,以便显示数据。
    3、设置数据模型:
  • 将数据模型设置给表格。
  • 将数据模型的输入设置为数据列表。
    4、更新数据数据。
  • 更新数据模型中的数据。
  • 调用refresh()方法来刷新表格,以便显示新的数据。

二、用例演示

复制代码
//创建数据模型
public class Persion {
    private String name;
   	private int age;
//省略构造方法和其他方法,省略getter和setter方法
}
    //创建内容提供器
    //并实现接口IStructuredContentProvider和ITableLabelProvider
public class PersonTableModel implements IStructuredContentProvider,ITableLabelProvider{
    private List<Persion> data;
    public PersonTableModel(List<Persion> data) {
    	this.data = data;
    }
    //获取元素
    @Override
    public Object[] getElements(Object inputElement) {
    	return data.toArray();
    }
    
    @Override
    public void dispose() {}
    
    @Override
    public void inputChanged(Viewer viewer, Object oldInput, Object newInput) {}
    
    //获取列文本
    @Override
    public String getColumnText(Object element, int columnIndex) {
    	Persion persion = (Persion)element;
    	switch (columnIndex) {
    		case 0:
    			return persion.getName();
    		case 1:
    			return String.valueOf(Persion.getAge());
    		default:
    			return "";
    	}
    }
    
    //获取列图像
    @Override
	public Image getColumnImage(Object element, int columnIndex) {
		return null;
	}
}

//创建表格
TableViewer viewer = new TableViewer(parent,SWT.MULTI | style);
GridData gridData = new GridData(GridData.FILL_BOTH);
viewer.getControl().setLayoutData(gridData);

//新建列并设置标签提供器
TableViewerColumn column = new TableViewerColumn(viewer, SWT.None);
column.getColumn().setWidth(100);
column.getColumn().setText("姓名");
column.setLabelProvider(new ColumnLabelProvider() {
	@Override
	public String getText(Object element) {
		Persion persion = (Persion)element;
		return persion.getName();
	}
});

column = new TableViewerColumn(viewer, SWT.None);
column.getColumn().setWidth(100);
column.getColumn().setText("年龄");
column.setLabelProvider(new ColumnLabelProvider() {
	@Override
	public String getText(Object element) {
		Persion persion = (Persion)element;
		return String.valueOf(Persion.getAge());
	}
});

//设置数据模型
List<Persion> dataList = new ArrayList<>();
dataList.add(new Persion("zhangsan",23));
dataList.add(new Persion("lisi",43));

//设置内容提供器
viewer.setContentProvider(new PersonTableModel(dataList));
viewer.setInput(dataList);

//数据更新
data.add(new Persion("wangwu",33));
viewer.refresh();
相关推荐
不秃的开发媛3 分钟前
JFace中MVC的表的单元格编辑功能的实现
java·开发语言·mvc
好奇的菜鸟10 分钟前
MyBatis-Plus 中 QueryWrapper 的 Limit 实现
java·tomcat·mybatis
_Tenk_10 分钟前
Java SpringBoot 扣子CozeAI SseEmitter流式对话完整实战 打字机效果
java·spring boot·语言模型·ai编程·智能体·coze扣子
努力学习的小廉11 分钟前
我爱学算法之—— 二分查找(中)
开发语言·c++·算法
越来越无动于衷17 分钟前
java错题
java·算法
只_只21 分钟前
A1012 PAT甲级JAVA题解 The Best Bank
开发语言·python
l_tian_tian_21 分钟前
SpringCloud——MybatisPlus
java·spring boot·mybatis
fashia27 分钟前
Java转Go日记(五十六):gin 渲染
开发语言·后端·golang·go·gin
北漂老男孩40 分钟前
Flink基于Yarn多种启动方式详解
java·大数据·flink
王蛋11141 分钟前
后端环境配置
java·spring·maven