JTable表头排序的两种方法

关键词:JTable,表头排序,线程安全

在Java6以前,关于JTable的表头排序是一件非常费力的事情,因为很多复杂的工作都要自己去做,但到了Java6,表头排序就变得非常简单了就一行代码:setRowSorter(new TableRowSorter<TableModel>(defaultTableModel));不过我经过实验,发现这个方法其实不怎么好用:
1. 速度比较慢,进行表头排序的时候,总觉得页面刷新有些迟缓
2. 点击表头的响应速度太慢了。用比较快的速度点表头,很多时候页面根本不响应点击事件。
3. 表头的排序箭头是默认的,比较难看

造成以上问题的原因无非有两个,一个是TableRowSorter类比较新,没有进行优化,二是对TableRowSorter类认识不够。

下面说一下Java5及一下版本中的表头排序
Java5一下进行表头排序,必须要写很多的代码~~~,不过这样也有好处,就是式样和效率可以自己控制,所以自己写的表头排序比Java6默认的TableRowSorter好看很多,也快很多,这就复杂一些也是值得的,下面比较一下二者的表现差异。
下图是 java5的表头排序画面:


下图是 java6的表头排序画面:

怎么样,我们根据ID排序,利用自己的表头排序样式好看一些,速度和相应明显比使用TableRowSorter好很多。

Java5中完成表头排序的代码是比较多的也比较复杂,我想这也是为什么Java6对它进行包装的原因吧,我这里只列出构造函数的代码,更完整的代码见附件
public ZTableJava5(TableModel dm) {
		super(dm, null, null);

		JTableHeader jtableheader = getTableHeader();
		jtableheader.addMouseListener(new MouseAdapter() {
			public void mouseClicked(MouseEvent event) {
				if (event.getSource() == getTableHeader()) {
					getTableHeader().removeMouseListener(this);
					int i = columnAtPoint(event.getPoint());
					int j = convertColumnIndexToModel(i);

					if (!columnIsSortable(j)) {
						return;
					}
					if (j == sortColumn) {
						ascending = !ascending;
					} else {
						ascending = true;
						sortColumn = j;
					}

					EventQueue.invokeLater(new Runnable() {
						public void run() {
							sort();
						}
					});

					getTableHeader().addMouseListener(this);
				}
			}
		});
		jtableheader.setDefaultRenderer(createHeaderRenderer());
		if (getRowCount() > 0) {
			EventQueue.invokeLater(new Runnable() {
				public void run() {
					reinitialize();
				}
			});
		}
		// setRowSorter(new TableRowSorter<TableModel>(defModel));
	}

Java6中完成表头排序的代码非常简单:
public ZTableJava6(TableModel dm) {
		super(dm, null, null);

		DefaultTableModel defModel = (DefaultTableModel) getModel();
		setRowSorter(new TableRowSorter<TableModel>(defModel));
	}


完整的程序请参考附件

你可能感兴趣的:(swing,jtable,表头排序)