【发布时间】:2023-04-04 13:06:01
【问题描述】:
我正在寻找解决此问题的方法: 我有一个包含数据的 excel 文件。一些单元格有黄色背景。我已经创建了一个用于将文本导入 JTable 的代码,它工作正常。但我也想将背景单元格颜色导入特定单元格。为简单起见,我没有使用循环,从源代码读取 excel 数据等。阅读论坛后,我明白我需要 CustomCellRenderer。
我对这种方法有疑问,因为此代码起初正确地为列中的单元格着色,但是当我开始滚动此表中的彩色单元格时,它会将整个列重新着色为黄色。 (见截图)
我想我可以添加 else 语句来专门将剩余的单元格着色为白色,但这种方法对我不起作用,因为我会覆盖我以前的单元格结果。
你能给我指出一个解决方案吗? (这是一个错误,还是 JTable 的预期行为?)。我正在使用 NetBeans 和 GUI 拖放生成器
import java.awt.Color;
import java.awt.Component;
import javax.swing.JTable;
import javax.swing.table.DefaultTableCellRenderer;
public class MyRenderer extends DefaultTableCellRenderer {
@Override
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) {
Component c = super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);
int[][] coordinatesYellow = new int[3][2];
//[row][column] these cells are yellow
coordinatesYellow[0][0] = 3;
coordinatesYellow[0][1] = 2;
coordinatesYellow[1][0] = 4;
coordinatesYellow[1][1] = 2;
coordinatesYellow[2][0] = 2;
coordinatesYellow[2][1] = 2;
for (int i = 0; i < 3; i++) {
if ((row == coordinatesYellow[i][0]) && (column == coordinatesYellow[i][1])) {
c.setBackground(Color.yellow);
}
}
return c;
}
}
// And this is the statement I use for calling the renderer:
// resultsTable.getColumnModel().getColumn(0).setCellRenderer(new MyRenderer());
【问题讨论】:
-
@TT - 您的评论基本上是一个完整的答案。
-
@tucuxi 是的,这听起来很琐碎,我发表了评论。我已经给出了答案。
-
另见stackoverflow.com/questions/22606227/colored-table-cells(甚至可能是重复的......)
标签: java jtable tablecellrenderer