一起使用TableCellRenderer和getColumnClass

当我将getcolumn类添加到我的abstracttablemodel时,我无法使用我的自定义TableCellRenderer来设置背景颜色。 (我用它来排序,对齐数字列)

public Class getColumnClass(int columnIndex) { Object o = getValueAt(0, columnIndex); if (o == null) { return Object.class; } else { return o.getClass(); } } 

这充满了我的代码。

 import java.awt.*; import java.text.DecimalFormat; import javax.swing.*; import static javax.swing.JFrame.EXIT_ON_CLOSE; import javax.swing.table.*; public class DemoRenderer extends JFrame { public static void main( String[] args ) { DemoRenderer frame = new DemoRenderer(); frame.setDefaultCloseOperation( EXIT_ON_CLOSE ); frame.pack(); frame.setVisible( true ); } public DemoRenderer() { JTable table = new JTable(); table.setModel(new MyTablemodel()); table.setDefaultRenderer(Object.class, new MyCustomTableCellRenderer()); // Tell the table what to use to render our column of doubles table.repaint(); //table.getColumnModel().getColumn(1).setCellRenderer(new DecimalFormatRenderer() ); getContentPane().add(new JScrollPane(table)); } } /** Here is our class to handle the formatting of the double values */ class MyCustomTableCellRenderer extends DefaultTableCellRenderer{ private static final DecimalFormat formatter = new DecimalFormat( "#0.00" ); public Component getTableCellRendererComponent (JTable table, Object obj, boolean isSelected, boolean hasFocus, int row, int column) { if(column==1) obj = formatter.format((Number)obj); Component cell = super.getTableCellRendererComponent( table, obj, isSelected, hasFocus, row, column); if (isSelected) { cell.setBackground(Color.green); } else { if (row % 2 == 0) { cell.setBackground(Color.cyan); } else { cell.setBackground(Color.lightGray); } } return cell; } } class MyTablemodel extends AbstractTableModel{ Object[] columnNames = { "A", "B", "C" }; Object[][] data = { { "1abc", new Double(850.503), 53 }, { "2def", new Double(36.23254), 6 }, { "3ghi", new Double( 8.3 ), 7 }, { "4jkl", new Double( 246.0943 ), 23 }}; @Override public int getRowCount() { return data.length; } @Override public int getColumnCount() { return columnNames.length; } @Override public Object getValueAt(int rowIndex, int columnIndex) { return data[rowIndex][columnIndex]; } public Class getColumnClass(int columnIndex) { Object o = getValueAt(0, columnIndex); if (o == null) { return Object.class; } else { return o.getClass(); } } } 

非常感谢你的意见。

您的getColumnClass()方法将返回:列0,1,2的String.class,Double.class和Integer.class。

JTable将为Double和Integer列提供默认渲染器。

如果要对所有列使用自定义渲染器,则需要执行以下操作:

 MyCustomTableCellRenderer renderer = new MyCustomTableCellRenderer(); table.setDefaultRenderer(Object.class, renderer); // or you could use "String.class" table.setDefaultRenderer(Double.class, renderer); table.setDefaultRenderer(Integer.class, renderer); 

当您使用“Object.class”时,它意味着使用Object渲染器作为最后的渲染器,只有在表中没有添加特定类的其他自定义渲染器时。

使用TableColumn #setCellRenderer()为每列绘制单个值。

只需在代码中添加以下行

 MyCustomTableCellRenderer cellRenderer = new MyCustomTableCellRenderer(); for (int i = 0; i < table.getColumnCount(); i++) { table.getColumnModel().getColumn(i).setCellRenderer(cellRenderer); } 

代替

 table.setDefaultRenderer(Object.class, new MyCustomTableCellRenderer()); 

你的问题将得到解决。

注意:您正在使用将应用于单元格的DefaultTableCellRenderer ,因此使用setCellRenderer()而不是setDefaultRenderer()

截图:(选择了一行)

在此处输入图像描述