在运行时设置JTable的选项
概述
Jtable类提供丰富的网格数据显示功能。这个技巧处理有关动态改变诸如滚动条,列宽以及行高等通常的外观的问题 。 (900 words; 九月14, 2001) (九月 20,2001译)
Java基础类(JFC)为创建一个精巧和交互的图形用户界面(GUIs)提供了丰富的组件选择。你可以使用javax.swing.JTable 显示表格式的数据。在这个技巧中,我们研究如何JTable 的常见问题。
首先让我们定义一个最初的,基本的Jtable类?D?DMyTable:
import javax.swing.table.*;
import javax.swing.*;
import java.awt.*;
public class MyTable extends JTable{
//缺省构造函数
public MyTable(){
super();
}
//使用指定的行列数创建表格的构造函数
public MyTable(int row, int col){
super(row, col);
}
}
相当简单!! 我们最初的 MyTable 实现就是一个普通的Jtable 。
下一节,我们将致力于不同的JTable 显示选项?D?D例如滚动条,列宽,选择性以及其它一些属性。我们将扩充MyTable 并且合并一些不同的方法使得它支持我们想要的显示特性。每一节增加一个新方法到MyTable ,最后我们得到一个可完全复用的Jtable 。
滚动表格
首先,让我们的JTable 显示一些表格式的数据。我创建TableColumnTest示范Jtable 的能力:
import javax.swing.table.*;
import javax.swing.*;
import java.awt.event.*;
import java.awt.*;
/**Author Sonal Goyal,
sonal_goyal@hotmail.com
*/
public class TableColumnTest{
protected JFrame frame;
protected JScrollPane scrollpane;
protected MyTable table;
public TableColumnTest(){
//(1) 创建表格模型。
DefaultTableModel dm = new DefaultTableModel();
// 每列的名字
String[] columnNames = {
"This is going to be a really long column header",
"Column B", "Column C", "Column D", "Column E", "Column F",
"Column G", "Column H", "Column I", "Column J"
};
// 实际的数据值
Integer[][] data = new Integer[8][10];
// 初始化数据矩阵。
for (int row = 0; row < 8; row++){
for (int col = 0; col < 10; ++col){
data[row][col] = new Integer(1000000);
}
}
// 设置模型和数据及列头关联
dm.setDataVector(data, columnNames);
//(2) 创建表格
table = new MyTable();
//(3) 连接模型和表格
table.setModel(dm);
//(4) 为表格创建滚动面板
scrollpane = new JScrollPane(table);
//(5) 显示表格
frame = new JFrame();
frame.getContentPane().add(scrollpane);
frame.setSize(200, 150);
frame.setVisible(true);
}
public static void main(String[] args){
TableColumnTest test = new TableColumnTest();
}
示范程序相当简单。我们通过下面的步骤构造了一个简单的JTable:
创建并设置TableModel, 它包含行,列,列头以及数据数据的信息
创建并设置JTable, 它根据模型显示数据将JTable 和第一步创建的模型关联
这些列被保存在一个String数组里:
String[] columnNames = {"Product","Number of Boxes","Price"};
数据被初始化并保存在一个二维的对象数组里:
Object[][] data =
{
{"Apples", new Integer(5),"5.00"},
{"Oranges", new Integer(3),"6.00"},
{"Pears", new Integer(2),"4.00"},
{"Grapes", new Integer(3),"2.00"},
};
JTable是使用data和columnNames构成的:
JTable table = new JTable(data, columnNames);
JTable的高度和宽度按照下面的方法来设定:
table.setPreferredScrollableViewportSize(new Dimension(300, 80));
如果JTable的一个列或者JTable窗口自身的大小被重新确定,那么其他列会
被相应的缩小或者放大,以适应新的窗口。使用setAutoResizeMode()方法
就能够控制这种行为:
table.setAutoResizeMode(int mode);
mode整数字段可能的值有:
AUTO_RESIZE_OFF
AUTO_RESIZE_NEXT_COLUMN
AUTO_RESIZE_SUBSEQUENT_COLUMNS
AUTO_RESIZE_LAST_COLUMN
AUTO_RESIZE_ALL_COLUMNS
表格的缺省值
单元格内方格坐标线的缺省颜色是Color.gray。要更改这些方格坐标线的颜
色,就要用到:
table.setGridColor(Color.black);
你可以用下面的方法来改变行的高度:
table.setRowHeight(intpixelHeight);
各个单元格的高度将等于行的高度减去行间的距离。
在缺省情况下,内容的前景颜色和背景颜色的选择都是由Swing的所见即所
得的实现来确定的。你可以使用下面的方法来更改选择的颜色:
table.setSelectionBackground(Color.black);
table.setSelectionForeground(Color.white);
你也可以隐藏单元格的方格坐标线,就像下面这样:
table.setShowHorizontalLines(false);
table.setShowVerticalLines(false);
列的宽度
JTable组件有几个控制表格特性的类和接口。TableColumn会不断追踪列的
宽度,并负责列大小的调整,包括最大和最小宽度。
TableColumnModel管理着TableColumns的集合以及列的选择。要设置某个列
的宽度,就要为表格列的模型设置一个参照。然后,取得想要的
TableColumn并调用其setPreferredWidth()方法:
TableColumncolumn = table.getColumnModel().getColumn(0);
column.setPreferredWidth(100);
当用户拖放列的时候,列的索引并不会发生改变。getColumn(0)方法会一直
返回正确的列,无论它出现在屏幕的哪个地方。
标题
JtableHeader会处理JTable标题的显示。你可以细分JtableHeader以获得自
定义的布局。例如,如果你的应用程序需要一个跨越多个列的标题,那么只
用简单地细分JtableHeader并将它集成到你的JTable里就行了。
你可以通过为当前JTable的JtableHeader设置一个参照或者调用其
setReorderingAllowed()方法,来指定标题的重新排序是否被允许:
table.getTableHeader().setReorderingAllowed(false);
类似地,你可以确信列不会因为在列标题之间拖动而改变大小。要达到这个
目的,你就要使用setResizingAllowed()方法:
table.getTableHeader().setResizingAllowed(false);
选择模式
在缺省状况下,当用户在JTable里选择一个单元格的时候,整个行都被选中
了。有多种方法能够让用户自定义选择的方式。利用ListSelectionModel接
口,你可以允许用户选择单个或者多个行:
table.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
ListSelectionModel有下面这些字段:
* SINGLE_SELECTION允许一次选择一行。
* SINGLE_INTERVAL_SELECTION允许选择相邻的一系列行。
* MULTIPLE_INTERVAL_SELECTION也允许选择相邻的列,但是带有扩展
功能。它允许用户使用[Ctrl]键进行多个互不相邻的选择(即选择不相邻的
行)。
setCellSelectionEnabled()方法让用户能够同时选择单个单元格或者整个
行:
table.setCellSelectionEnabled(true);
如果被设置为是,setCellSelectionEnabled()方法还会允许在选择行和单
个单元格的同时选择列
编辑单元格
我们这个简单的表格允许用户编辑表格里的任何单元格。Listing B列出了
一个表格,它允许由程序员来决定哪些单元格能够被编辑。第一步是创建一
个自定义的TableModel:
class SimpleTableModel extends AbstractTableModel {}
数据被封装在TableModel里,当JTable初始化的时候,自定义的TableModel
就被作为一个参数传递给JTable的构造函数而不是那个二维的对象数组:
SimpleTableModelmyModel = new SimpleTableModel();
JTable table = new JTable(myModel);
如果想让第二列和第三列也变得可以编辑,并把第一列变成恒定的,那么你
就要强制替代TableModel的isCellEditable()方法:
public booleanisCellEditable(int row, intcol){
if (col == 0) {return false;}
else {return true; }
}
简单的表格验证
你需要确保用户只输入整数值,假如说,向第二列("盒子的数量"这一列
)输入值来强制替代setValueAt()方法,并将验证逻辑包括进这个新方法里
。首先,你要检查列是否是整数,以及这个列是否只应该包含整数值:
if (data[0][col] instanceof Integer && !(value instanceof
Integer))
{... } else { data[row][col] = value;}
然后,检查被插入的值是否是个整数。如果它不是的,那么这个字段就不应
该被更新,而且应该要显示一条错误信息:
try {
data[row][col] = new Integer(value.toString());
} catch (NumberFormatException e) {
JOptionPane.showMessageDialog(SimpleTable.this,
"Please enter only integer values.");
}
背景颜色
Listing C包含了用于ColorTable.java的代码,它说明了如何向JTable加入
颜色。你可以通过强制替代其prepareRenderer()方法来向JTable加入背景
颜色:
JTable table = new JTable(data, columnNames){
public Component prepareRenderer(TableCellRenderer r, int row,
intcol){}
};
然后,插入决定哪些列应该有颜色以及应该是什么颜色的逻辑:
if (col == 2 && !isCellSelected(row, col)){
Color bg = new Color(200, 100, 30);
c.setBackground(bg);
c.setForeground(Color.white);
}
要注意,当你更改单元格背景颜色的时候,你还应该更该单元格里所显示的
文本的颜色,让其变得更加易读。图C显示了一个第一列和第二列加上了颜
色的JTable。
在运行时设置JTable的选项
发布时间: 2006-11-15 01:35 作者: cjc 信息来源: 姜堰市南苑学校家校互动平台
字体:
小
中
大
打印
package baseClass;
import java.awt.*;
import javax.swing.*;
import javax.swing.table.*;
import javax.swing.table.*;
public class TableRender {
public static void makeFace(JTable table)
{
try
{
DefaultTableCellRenderer tcr = new DefaultTableCellRenderer()
{
public Component getTableCellRendererComponent(JTable table,
Object value, boolean isSelected, boolean hasFocus,
int row, int column)
{
if(row%2 == 0)
{
setBackground(Color.white); //设置奇数行底色
}
else if(row%2 == 1)
{
setBackground(new Color(206,231,255)); //设置偶数行底色
}
if(table.getValueAt(row, 0).toString().equals("0"))
{
setBackground(Color.red);
}
return super.getTableCellRendererComponent(table, value,
isSelected, hasFocus, row, column);
}
};
for(int i = 0; i < table.getColumnCount(); i++)
{
table.getColumn(table.getColumnName(i)).setCellRenderer(tcr);
}
}
catch (Exception ex)
{
ex.printStackTrace();
}
}
public static void makeFace(JTable table)
{
try
{
DefaultTableCellRenderer tcr = new DefaultTableCellRenderer()
{
public Component getTableCellRendererComponent(JTable table,
Object value, boolean isSelected, boolean hasFocus,
int row, int column)
{
if(row%2 == 0)
{
setBackground(Color.white); //设置奇数行底色
}
else if(row%2 == 1)
{
setBackground(new Color(206,231,255)); //设置偶数行底色
}
if(table.getValueAt(row, 0).toString().equals("0"))
{
setBackground(Color.red);
}
return super.getTableCellRendererComponent(table, value,
isSelected, hasFocus, row, column);
}
};
for(int i = 0; i < table.getColumnCount(); i++)
{
table.getColumn(table.getColumnName(i)).setCellRenderer(tcr);
}
}
catch (Exception ex)
{
ex.printStackTrace();
}
}
}