在给自己的jtable控件加了jcombobox下拉控件后,只要鼠标一单击单元格就进入编辑状态了。有什么办法可以让其双击后才出现自己的控件进行编辑。 我发现只要加了自定义的控件,就会变成单击编辑。请问有什么办法可以像它默认那样,双击以后才进入编辑状态。谢谢了

解决方案 »

  1.   

    不会的,参考下面的代码:
    package swing;import java.awt.BorderLayout;
    import java.awt.Color;
    import java.awt.event.ActionEvent;
    import java.awt.event.ActionListener;
    import java.util.Vector;import javax.swing.DefaultCellEditor;
    import javax.swing.JButton;
    import javax.swing.JComboBox;
    import javax.swing.JFrame;
    import javax.swing.JPanel;
    import javax.swing.JScrollPane;
    import javax.swing.JTable;
    import javax.swing.table.AbstractTableModel;
    import javax.swing.table.TableColumnModel;/**
     * JTable的实用小例子
     * 
     * @author 五斗米 <如转载请保留作者和出处>
     * @blog http://blog.csdn.net/mq612
     */public class TestTable {
    private JFrame frame = null; private JTable table = null; private Table_Model model = null; private JScrollPane s_pan = null; private JButton button_1 = null, button_2 = null, button_3 = null; private JPanel pane = null; public TestTable() {
    frame = new JFrame("JTableTest");
    pane = new JPanel();
    button_1 = new JButton("清除数据");
    button_1.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent e) {
    removeData();
    }
    });
    button_2 = new JButton("添加数据");
    button_2.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent e) {
    addData();
    }
    });
    button_3 = new JButton("保存数据");
    button_3.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent e) {
    saveData();
    }
    });
    pane.add(button_1);
    pane.add(button_2);
    pane.add(button_3);
    model = new Table_Model(20);
    table = new JTable(model);
    table.setBackground(Color.pink);
    table.setRowHeight(25);
    String[] age = { "16", "17", "18", "19", "20", "21", "22" };
    JComboBox com = new JComboBox(age);
    TableColumnModel tcm = table.getColumnModel();
    tcm.getColumn(3).setCellEditor(new DefaultCellEditor(com));
    tcm.getColumn(0).setPreferredWidth(50);
    tcm.getColumn(1).setPreferredWidth(100);
    tcm.getColumn(2).setPreferredWidth(50); s_pan = new JScrollPane(table); frame.getContentPane().add(s_pan, BorderLayout.CENTER);
    frame.getContentPane().add(pane, BorderLayout.NORTH);
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    frame.setSize(300, 200);
    frame.setVisible(true); } private void addData() {
    model.addRow("李逵", true, "19");
    table.updateUI();
    } private void removeData() {
    model.removeRows(0, model.getRowCount());
    table.updateUI();
    } // 保存数据,暂时是将数据从控制台显示出来
    private void saveData() {
    int col = model.getColumnCount();
    int row = model.getRowCount();
    for (int i = 0; i < col; i++) {
    System.out.print(model.getColumnName(i) + "\t");
    }
    System.out.print("\r\n");
    for (int i = 0; i < row; i++) {
    for (int j = 0; j < col; j++) {
    System.out.print(model.getValueAt(i, j) + "\t");
    }
    System.out.print("\r\n");
    }
    System.out.println("------------------------------------");
    } public static void main(String args[]) {
    new TestTable();
    }}/**
     * TableModel类,继承了AbstractTableModel
     * 
     * @author 五斗米
     * 
     */
    class Table_Model extends AbstractTableModel { private static final long serialVersionUID = -7495940408592595397L; private Vector content = null; private String[] title_name = { "ID", "姓名", "性别", "年龄" }; public Table_Model() {
    content = new Vector();
    } public Table_Model(int count) {
    content = new Vector(count);
    } public void addRow(String name, boolean sex, String age) {
    Vector v = new Vector(4);
    v.add(0, new Integer(content.size()));
    v.add(1, name);
    v.add(2, new Boolean(sex));
    v.add(3, age);
    content.add(v);
    } public void removeRow(int row) {
    content.remove(row);
    } public void removeRows(int row, int count) {
    for (int i = 0; i < count; i++) {
    if (content.size() > row) {
    content.remove(row);
    }
    }
    } /**
     * 让表格中某些值可修改,但需要setValueAt(Object value, int row, int col)方法配合才能使修改生效
     */
    public boolean isCellEditable(int rowIndex, int columnIndex) {
    if (columnIndex == 0) {
    return false;
    }
    return true;
    } /**
     * 使修改的内容生效
     */
    public void setValueAt(Object value, int row, int col) {
    ((Vector) content.get(row)).remove(col);
    ((Vector) content.get(row)).add(col, value);
    this.fireTableCellUpdated(row, col);
    } public String getColumnName(int col) {
    return title_name[col];
    } public int getColumnCount() {
    return title_name.length;
    } public int getRowCount() {
    return content.size();
    } public Object getValueAt(int row, int col) {
    return ((Vector) content.get(row)).get(col);
    } /**
     * 返回数据类型
     */
    public Class getColumnClass(int col) {
    return getValueAt(0, col).getClass();
    }}
      

  2.   

    以上代码显然不能反应我的问题,我说的是使用了自定义的编辑器以后才会变成单击编辑。而上面代码没看出来有任何自定义的编辑器,最多一个自定义的model
      

  3.   

    嗯,很早啊~~
    那么,既然你说自定义的编辑器,那么一定会使用继承默认的CellEditor或者实现相应的接口。
    当然默认的编辑器也实现了CellEditor接口。
    或许你没有注意到,有这样的一个方法:isCellEditable
    boolean isCellEditable(EventObject anEvent)询问编辑器它是否可以使用 anEvent 开始进行编辑。anEvent 在将要调用的组件的坐标系统中。编辑器不能假定由 getCellEditorComponent 返回的 Component 已被安装。此方法供客户端使用,以避免不可能进行编辑时设置和安装编辑器组件所带来的花费。如果可以开始进行编辑,则此方法返回 true。 参数:
    anEvent - 编辑器考虑是否开始进行编辑时应该使用的事件 
    返回:
    如果可开始进行编辑,则返回 true改写此方法,足矣。若还有问题,请描述的更详细一些