Bla*_* BK 5 java swing calendar jtable
我创建了一个交互式日历作为JTable,但是,我想根据我拥有的数据更改某些单元格的背景颜色.我想出了如何获得我需要编辑的单元格的位置,但我不知道如何将单元格作为一个组件放在该位置,这样我就可以编辑单元格背景和前景.
所以基本上我有单元格的(x,y)位置.我想使用它并让细胞改变它的背景颜色.
这就是我创建日历的方式:
public static JTable createInteractiveCalender(int month, int year) {
JTable calender = new JTable(Calender.getMonthsCalender(month, year), new String[] {"Su","Mo","Tu","Wed","Th","Fri","Sat"}){
public boolean isCellEditable(int row, int column) {
return false;
};
};
calender.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
calender.setCellSelectionEnabled(true);
return calender;
}
Run Code Online (Sandbox Code Playgroud)
这就是我得到我想要标记的日期的方式:
public static ArrayList<Date> getDatesInSpecificMonth(ArrayList<Date> allDates, int month) {
DateFormat df = new SimpleDateFormat("MM");
ArrayList<Date> dates = allDates;
for (Date d: dates)
if(Integer.parseInt(df.format(d)) != month)
dates.remove(d);
return dates;
}
Run Code Online (Sandbox Code Playgroud)
这是我试图在日历上标记日期时遇到的问题:
public static void markDatesOnCalender(DefaultTableModel model, Section sec, int datesToMark, int month, int year) {
ArrayList<Date> dates = Calender.getDatesInSpecificMonth(sec.getSelectedDatesforSection(datesToMark),month);
DateFormat df = new SimpleDateFormat("dd");
for (Date d: dates) {
model.getValueAt(getCellPosition(model,df.format(d))[0],getCellPosition(model, d
f.format(d))[1]);
/*
I have method that gets the cell position of 'd', however I need to get the
*/
}
//TODO 1
}
Run Code Online (Sandbox Code Playgroud)
谢谢
JTable的单元格不是传统意义上的组件,即您不能将它们作为JTable组件的子组件.
相反,当渲染JTabel时,对于每个单元格,a TableCellRenderer提供一个JComponent,用于在该方法中将该单元格绘制在所需位置TableCellRenderer.getTableCellRendererComponent(...).
需要注意的是,JComponent所提供TableCellRenderer.getTableCellRendererComponent(...)的不添加到组件树,而是用来临时绘制相应的表格单元格.实际上,大多数TableCellRenderer实现对所有单元使用相同的组件实例,重新设置每个单元的相关属性(最值得注意的是要显示的文本).
因此,在您的情况下,您需要做的是存储驱动单元格数据中单元格着色的相关属性,然后使用自定义TabelCellRenderer.渲染器读取这些属性并返回基于这些属性配置的JComponent.
例如:该类Cell表示表格单元格的内容.您在这里使用的是什么类取决于您要使用的表模型.它可能很简单String,但是如果你想根据某些属性渲染表格单元格,你需要使用一个基于类的表模型来保存该属性,因此自定义类Cell:
class Cell{
...
String text;
boolean isHighlighted;
...
}
class MyTableCellRenderer implements TableCellRenderer{
// cellLabel will be used to render each cell. Note that
// this component is re-used for painting each cell, we
// don't have separate instances for all cells.
private JLabel cellLabel=new JLabel();
@Override
public Component getTableCellRendererComponent(
JTable table,
Object value,
boolean isSelected,
boolean hasFocus,
int row,
int column) {
Cell cell=(Cell)value;
cellLabel.setText(cell.getText());
if(cell.isHighlighted)
cellLabel.setForeground(Color.RED);
}
}
Run Code Online (Sandbox Code Playgroud)
请注意,您必须设置TableCellRenderer,并且可以针对特定列类执行此操作:
table.setDefaultRenderer(columnClass, renderer);
Run Code Online (Sandbox Code Playgroud)
最后,一旦改变了单元格的属性,就必须强制重新绘制JTable.正如@trashgod指出的那样,当您正确更新表模型并通知其监听器时,JTable应自动重新绘制(因为它是一个TableModelListener向模型注册并侦听模型更改的模板).