1

我使用 DefaultTableModel 如下:

  DefaultTableModel model = new DefaultTableModel (COLUMNS, 0 )
  {
      @Override
      public boolean isCellEditable(int row, int column)
      {
          return (getColumnName(column).equals("Selected"));
      }

      public Class getColumnClass(int columnIndex)
      {
          if(getColumnName(columnIndex).equals("Selected"))
              return Boolean.class;
          return super.getColumnClass(columnIndex);
      }     
  };

现在我只想在“已选择”列中选择一个复选框。如何才能做到这一点。我也尝试过以下方法,但它不起作用。

 public void fireTableCellUpdated(int row,int column)
 {
     if(getColumnName(column).equals("Selected"))
     {
         for(int i = 0; i<getRowCount() && i!=row;i++)
            setValueAt(Boolean.FALSE, row, column);
     }
 }
4

3 回答 3

1
  • @eatSleepCode 写了@mKorbel 你能给出实现 setValueAt 方法的示例代码吗?

  • (使用的OP)DefaultTableModel的代码,

  • 对于基于的代码,AbstractTableModel需要保存通知程序的代码排序fireTableCellUpdated(rowIndex, columnIndex);,因为/否则不会重新绘制任何内容JTables view

  • 这两个模型及其通知器之间有一些重要的区别,并且(我的观点)没有理由打扰和使用AbstractTableModel基本的东西(99pct 的表模型)

在此处输入图像描述. . . . 在此处输入图像描述. . . .在此处输入图像描述

import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.SwingUtilities;
import javax.swing.table.DefaultTableModel;

public class TableRolloverDemo {

    private JFrame frame = new JFrame("TableRolloverDemo");
    private JTable table = new JTable();
    private String[] columnNames = new String[]{"Column"};
    private Object[][] data = new Object[][]{{false}, {false}, {true}, {true},
        {false}, {false}, {true}, {true}, {false}, {false}, {true}, {true}};

    public TableRolloverDemo() {
        final DefaultTableModel model = new DefaultTableModel(data, columnNames) {
            private boolean ImInLoop = false;

            @Override
            public Class<?> getColumnClass(int columnIndex) {
                return Boolean.class;
            }

            @Override
            public boolean isCellEditable(int rowIndex, int columnIndex) {
                return true;
            }

            @Override
            public void setValueAt(Object aValue, int rowIndex, int columnIndex) {
                if (columnIndex == 0) {
                    if (!ImInLoop) {
                        ImInLoop = true;
                        Boolean bol = (Boolean) aValue;
                        super.setValueAt(aValue, rowIndex, columnIndex);
                        for (int i = 0; i < this.getRowCount(); i++) {
                            if (i != rowIndex) {
                                super.setValueAt(!bol, i, columnIndex);
                            }
                        }
                        ImInLoop = false;
                    }
                } else {
                    super.setValueAt(aValue, rowIndex, columnIndex);
                }
            }
        };
        table.setModel(model);
        table.setPreferredScrollableViewportSize(table.getPreferredSize());
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.add(new JScrollPane(table));
        frame.pack();
        frame.setLocationByPlatform(true);
        frame.setVisible(true);
    }


    public static void main(String[] args) {
        SwingUtilities.invokeLater(new Runnable() {
            @Override
            public void run() {
                TableRolloverDemo tableRolloverDemo = new TableRolloverDemo();
            }
        });
    }
}
于 2013-07-30T12:01:39.643 回答
0

你会得到一个堆栈溢出异常,因为 setValueAt() 方法一次又一次地触发 fireTableCellUpdated() 方法。

相反,请尝试使用表侦听器来侦听复选框的值更改并将所有其他复选框的值设置为 false。

于 2013-07-30T10:35:17.283 回答
-1

您可以创建自己的自定义单元格编辑器,将ButtonGroup. 就是这样:

public class VeryComplicatedCellEditor extends DefaultCellEditor {
    private ArrayList<ButtonGroup> groups;

    public getTableCellEditorComponent(JTable table, Object value, boolean isSelected, int row, int column) {
        JCheckBox checkBox = new JCheckBox();
        growToSize(column);
        groups.get(column).add(checkBox);
        return checkBox;
    }

    private growToSize(int size) {
        groups.ensureCapacity(size);
        while (groups.size() < size)
            groups.add(new ButtonGroup());
    }
}

由于我们不知道表有多大,因此存在一些复杂性,这些问题主要在growToSize方法中得到处理。

其工作方式是维护一个ButtonGroups 列表,每列一个。每个单元格的编辑器组件被添加到其列的按钮组中。

于 2013-07-30T10:40:12.143 回答