我正在寻找解决此问题的方法: 我有一个包含数据的excel文件。一些细胞具有黄色背景。我已经创建了一个代码,用于将文本导入JTable,工作正常。但我也想将背景单元格颜色导入特定单元格。为了简单起见,我没有使用循环,从源代码中读取excel数据等。阅读论坛后我明白我需要CustomCellRenderer。
这个方法有问题,因为这个代码首先正确地对列中的单元格进行着色,但是当我开始滚动此表中的彩色单元格时,它会将整个列重新着色为黄色。 (见截图)
我以为我可以添加else语句来专门将剩余的单元格变为白色,但这种方法对我来说不起作用,因为我会覆盖以前的单元格结果。
你能指点我解决这个问题吗? (这是一个bug,还是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());
答案 0 :(得分:2)
如果您的单元格不应为黄色,则将背景设置为白色(或表格的背景颜色)。
扩展DefaultTableCellRenderer
的渲染器使用相同的组件(JLabel
)作为所有单元格的模板(参见DefaultTableCellRenderer
实施说明 - 他们称之为橡皮图章)。将背景设置为黄色后,它将保持黄色以呈现连续的单元格,直到您再次更改其背景颜色。
用以下内容替换你的for循环:
boolean isYellow = false;
for (int i = 0; i < 3; i++) {
if ((row == coordinatesYellow[i][0]) && (column == coordinatesYellow[i][1])) {
c.setBackground(Color.yellow);
isYellow = true;
}
}
if( !isYellow )
c.setBackground(Color.white);