JLo*_*ngo 1 java swing jtable tablecellrenderer
我对Java很新,我遇到JTable了排序和问题TableCellRenderer.
我有一个15列填充了值的表,在某些列上,我使用它TableCellRenderer来将前景的颜色更改为绿色或红色,根据单元格上的值.
一切都工作得很好,直到我尝试按一些列排序(排序部分没问题)......问题是格式化颜色不能反映排序操作所做的更改.在排序之前,颜色在桌子上的原始位置保持不变.有没有一种简单的方法可以解决这个问题?
我搜索过,但是我找不到可以实现的解决方案.
TIA
JL
编辑:发布相关源代码(未完成实现)
private void buildTab(){
myIUserInterface.removeBottomTab("just a test");
myJPanel = myIUserInterface.getBottomTab("just a test");
myJScollPane = new JScrollPane();
myTable = new JTable();
myTable.setAutoCreateRowSorter(true);
myTableContent = myFillTableData();
String[] tableHeaders = {
"X1", "X2", "X3", "X4", "X5", "X6", "X7", "X8", "X9", "X10", "X11", "X12", "X13", "X14", "X15"
};
myTable.setModel(new DefaultTableModel(myTableContent, tableHeaders) {
@Override
public boolean isCellEditable(int rowIndex, int columnIndex) {
return false;
}
});
MyChangeCellColor myCCC = new MyChangeCellColor();
Enumeration<TableColumn> allColumns = myTable.getColumnModel().getColumns();
while(allColumns.hasMoreElements()){
TableColumn column = allColumns.nextElement();
column.setCellRenderer(myCCC);
}
myJScollPane.setViewportView(myTable);
GroupLayout myLayout = new GroupLayout(myJPanel);
myJPanel.setLayout(myLayout);
myLayout.setHorizontalGroup(
myLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(myJScollPane, javax.swing.GroupLayout.DEFAULT_SIZE, 890, Short.MAX_VALUE)
);
myLayout.setVerticalGroup(
myLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(myJScollPane, javax.swing.GroupLayout.DEFAULT_SIZE, 672, Short.MAX_VALUE)
);
}
class MyChangeCellColor extends JLabel implements TableCellRenderer {
@Override
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected,
boolean hasFocus, int row, int column) {
setHorizontalAlignment(CENTER);
setOpaque(true);
setBackground(Color.WHITE);
if (column == 0){
setForeground(Color.BLACK);
}
if (column == 1){
setForeground(Color.BLACK);
}
if (column == 2){
setForeground(Color.BLACK);
}
if (column == 3){
setForeground(Color.BLACK);
}
if (column == 4){
if ("LONG".equals(myTable.getModel().getValueAt(row, 4))) {
setForeground(Color.GREEN.darker());
}
if ("SHORT".equals(myTable.getModel().getValueAt(row, 4))) {
setForeground(Color.RED);
}
}
if (column == 5){
setForeground(Color.BLACK);
}
if (column == 6){
setForeground(Color.BLACK);
}
if (column == 7){
setForeground(Color.BLACK);
}
if (column == 8){
setForeground(Color.BLACK);
}
if (column == 9){
setForeground(Color.BLACK);
}
if (column == 10){
setForeground(Color.BLACK);
}
if (column == 11){
double d = Double.valueOf(myTable.getModel().getValueAt(row, 11).toString());
if (d > 0) {
setForeground(Color.GREEN.darker());
}
if (d == 0) {
setForeground(Color.BLACK);
}
if (d < 0) {
setForeground(Color.RED);
}
}
if (column == 12){
double d = Double.valueOf(myTable.getModel().getValueAt(row, 12).toString());
if (d > 0) {
setForeground(Color.GREEN.darker());
}
if (d == 0) {
setForeground(Color.BLACK);
}
if (d < 0) {
setForeground(Color.RED);
}
}
if (column == 13){
setForeground(Color.BLACK);
}
if (column == 14){
setForeground(Color.BLACK);
}
setText(value.toString());
return this;
}
}
Run Code Online (Sandbox Code Playgroud)
编辑2:解决方案喜欢和粘贴参考,如果有人需要它!只需要在TableCellRenderer类上引用JTable返回的行上的模型行(不确定它是否正确解释,无论如何你可以看到下面的更改):
class MyChangeCellColor extends JLabel implements TableCellRenderer {
@Override
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected,
boolean hasFocus, int row, int column) {
setHorizontalAlignment(CENTER);
setOpaque(true);
setBackground(Color.WHITE);
if (column == 0){
setForeground(Color.BLACK);
}
if (column == 1){
setForeground(Color.BLACK);
}
if (column == 2){
setForeground(Color.BLACK);
}
if (column == 3){
setForeground(Color.BLACK);
}
if (column == 4){
if ("LONG".equals(myTable.getModel().getValueAt(myTable.convertRowIndexToModel(row), 4))) {
setForeground(Color.GREEN.darker());
}
if ("SHORT".equals(myTable.getModel().getValueAt(myTable.convertRowIndexToModel(row), 4))) {
setForeground(Color.RED);
}
}
if (column == 5){
setForeground(Color.BLACK);
}
if (column == 6){
setForeground(Color.BLACK);
}
if (column == 7){
setForeground(Color.BLACK);
}
if (column == 8){
setForeground(Color.BLACK);
}
if (column == 9){
setForeground(Color.BLACK);
}
if (column == 10){
setForeground(Color.BLACK);
}
if (column == 11){
double d = Double.valueOf(myTable.getModel().getValueAt(myTable.convertRowIndexToModel(row), 11).toString());
if (d > 0) {
setForeground(Color.GREEN.darker());
}
if (d == 0) {
setForeground(Color.BLACK);
}
if (d < 0) {
setForeground(Color.RED);
}
}
if (column == 12){
double d = Double.valueOf(myTable.getModel().getValueAt(myTable.convertRowIndexToModel(row), 12).toString());
if (d > 0) {
setForeground(Color.GREEN.darker());
}
if (d == 0) {
setForeground(Color.BLACK);
}
if (d < 0) {
setForeground(Color.RED);
}
}
if (column == 13){
setForeground(Color.BLACK);
}
if (column == 14){
setForeground(Color.BLACK);
}
setText(value.toString());
return this;
}
}
Run Code Online (Sandbox Code Playgroud)
问题是格式化颜色不能反映排序操作所做的更改.
您的渲染器中的逻辑存在问题.您可能正在使用"视图行"而不是"模型行"访问表模型中的数据.
既然你没有发布你的SSCCE演示问题我不能给你一个特定的解决方案只是一个通用的解决方案.查看以下JTable方法:
convertRowIndexToModel(int viewRowIndex)
convertRowIndexToView(int modelRowIndex)
Run Code Online (Sandbox Code Playgroud)
渲染器接收视图行号.
| 归档时间: |
|
| 查看次数: |
1668 次 |
| 最近记录: |