Java 如何为JTable中的一列添加不同的单元格编辑器?
我有一个包含两列的JTable,它们都是JComboBox,为此我实现了自己的模型和重写方法。我否决的方法之一是:Java 如何为JTable中的一列添加不同的单元格编辑器?,java,swing,Java,Swing,我有一个包含两列的JTable,它们都是JComboBox,为此我实现了自己的模型和重写方法。我否决的方法之一是: public Class getColumnClass(int index) { return JComboBox.class; } 还创建了我自己的ComboBoxEditor和ComboBoxRender类,并设置了cellEditor和cellRenderer: column.setCellEditor(new ComboBoxEditor()); column.set
public Class getColumnClass(int index) {
return JComboBox.class;
}
还创建了我自己的ComboBoxEditor和ComboBoxRender类,并设置了cellEditor和cellRenderer:
column.setCellEditor(new ComboBoxEditor());
column.setCellRenderer(new ComboBoxRenderer());
现在我想做一些更改,以便第一列的一些单元格是JComboBox,一些单元格是标准文本数据
我怎样才能做到这一点
欢迎提供任何有用的建议您需要实现自己的
javax.swing.table.TableCellRenderer
,其中
根据您的业务逻辑,在
GetTableCellRenderComponent(JTable表、对象值、布尔isSelected、布尔hasFocus、int行、int列)返回不同的呈现器。
。对于TableCellEditor
接口也是如此。我通常重写table.getCellEditor(…)方法以返回适当的编辑器
也许是这样的:
import java.awt.*;
import java.awt.event.*;
import java.util.*;
import javax.swing.*;
import javax.swing.table.*;
public class TableComboBoxByRow extends JFrame
{
ArrayList editors = new ArrayList(3);
public TableComboBoxByRow()
{
// Create the editors to be used for each row
String[] items1 = { "Red", "Blue", "Green" };
JComboBox comboBox1 = new JComboBox( items1 );
DefaultCellEditor dce1 = new DefaultCellEditor( comboBox1 );
editors.add( dce1 );
String[] items2 = { "Circle", "Square", "Triangle" };
JComboBox comboBox2 = new JComboBox( items2 );
DefaultCellEditor dce2 = new DefaultCellEditor( comboBox2 );
editors.add( dce2 );
String[] items3 = { "Apple", "Orange", "Banana" };
JComboBox comboBox3 = new JComboBox( items3 );
DefaultCellEditor dce3 = new DefaultCellEditor( comboBox3 );
editors.add( dce3 );
// Create the table with default data
Object[][] data =
{
{"Color", "Red"},
{"Shape", "Square"},
{"Fruit", "Banana"},
{"Plain", "Text"}
};
String[] columnNames = {"Type","Value"};
DefaultTableModel model = new DefaultTableModel(data, columnNames);
JTable table = new JTable(model)
{
// Determine editor to be used by row
public TableCellEditor getCellEditor(int row, int column)
{
int modelColumn = convertColumnIndexToModel( column );
if (modelColumn == 1 && row < 3)
return (TableCellEditor)editors.get(row);
else
return super.getCellEditor(row, column);
}
};
System.out.println(table.getCellEditor());
JScrollPane scrollPane = new JScrollPane( table );
getContentPane().add( scrollPane );
}
public static void main(String[] args)
{
TableComboBoxByRow frame = new TableComboBoxByRow();
frame.setDefaultCloseOperation( EXIT_ON_CLOSE );
frame.pack();
frame.setVisible(true);
}
}
import java.awt.*;
导入java.awt.event.*;
导入java.util.*;
导入javax.swing.*;
导入javax.swing.table.*;
公共类TableComboBoxByRow扩展了JFrame
{
ArrayList编辑器=新的ArrayList(3);
公共表ComboxBoxByRow()
{
//创建用于每行的编辑器
字符串[]items1={“红色”、“蓝色”、“绿色”};
JComboxCombox1=新的JCombox1(项目1);
DefaultCellEditor dce1=新的DefaultCellEditor(comboBox1);
添加(dce1);
字符串[]items2={“圆”、“正方形”、“三角形”};
JComboBox Combox2=新的jCombox2(项目2);
DefaultCellEditor dce2=新的DefaultCellEditor(comboBox2);
添加(dce2);
字符串[]items3={“苹果”、“橘子”、“香蕉”};
JComboxCombox3=新的JCombox3(项目3);
DefaultCellEditor dce3=新的DefaultCellEditor(comboBox3);
添加(dce3);
//使用默认数据创建表
对象[][]数据=
{
{“颜色”,“红色”},
{“形状”,“正方形”},
{“水果”,“香蕉”},
{“纯”、“文本”}
};
字符串[]columnNames={“类型”,“值”};
DefaultTableModel=新的DefaultTableModel(数据、列名称);
JTable表格=新JTable(型号)
{
//确定行要使用的编辑器
公共表CellEditor getCellEditor(int行,int列)
{
int modelColumn=convertColumnIndexToModel(列);
if(modelColumn==1&&row<3)
return(TableCellEditor)editors.get(row);
其他的
返回super.getCellEditor(行、列);
}
};
System.out.println(table.getCellEditor());
JScrollPane scrollPane=新的JScrollPane(表);
getContentPane().add(滚动窗格);
}
公共静态void main(字符串[]args)
{
TableComboBoxByRow框架=新建TableComboxByRow();
frame.setDefaultCloseOperation(关闭时退出);
frame.pack();
frame.setVisible(true);
}
}
您可以使用instanceof
。用法:
Object o = new String("Test");
if (o instanceof String)
{
String s = (String) o;
// Do something with the string
}
因此,将JTable的数据矩阵如下所示Object[][]data=new Object[…][…]
然后,您可以在
DefaultTableCellRenderer
中使用instanceof
来检查对象是字符串还是JComboBox
。根据这一结果,可以像字符串
或JComboBox
那样进行渲染,如果使用自己的表模型,则覆盖会更方便
setValueAt(对象值,int行,int列)
方法,并尝试转换其中的输入数据
我将在代码中使用此解决方案。有人认为这种方法有问题吗?我认为重要的一点是“默认”渲染器使用了不适当的继承。是的,继承没有意义。应该使用两个渲染器的纯合成,并在需要时返回适当的一个。这非常有用camickr XD这工作非常好,非常感谢:D