带有列数据类型float的Java中的自定义表单元格编辑器



默认情况下,我们必须按Enter键两次以更改选择时,在编辑JTable中的单元格时更改选择。

为了覆盖此行为,我正在尝试编写一个自定义表单元格编辑器,在单个Enter Press时,在当前单元格中完成编辑,将选择更改为下一行,并且在新选择的单元格中启动了编辑,并且其内容是自动的选择。

整个方案对于整数工作正常,但对于浮点数据类型不正常。对于带有数据类型float/double的列,我获得错误

java.lang.illegalargumentException:不能格式化给定对象为数字

按下Enter以更改选择。

我正在使用以下代码,我在网上搜索时发现。

package javaapplication1;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.EventQueue;
import javax.swing.AbstractCellEditor;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableCellEditor;
import javax.swing.table.TableColumn;
import javax.swing.text.JTextComponent;
/**
 *
 * @author alqama
 */
public class test extends JPanel{
    
    private JTable table;
    
    test()
    {
        table = new JTable(){
        @Override
        public void changeSelection(    int row, int column, boolean toggle, boolean extend)
        {
            super.changeSelection(row, column, toggle, extend);
            if (editCellAt(row, column))
            {
                Component editor = getEditorComponent();
                editor.requestFocusInWindow();
                ((JTextComponent) editor).selectAll();
            }
        }};
        DefaultTableModel dtm = new javax.swing.table.DefaultTableModel(
                new Object [][] {
                    },
                new String [] { "Integer","Float"}
            ) {
                public Class getColumnClass(int col) {
                if(col==0) return java.lang.Integer.class;
                return java.lang.Float.class;
            }
            public boolean isCellEditable(int rowIndex, int columnIndex) {
                return true;
            }
        };
        table.setModel(dtm);
        CustomTableCellEditor et = new CustomTableCellEditor(table);
        table.getColumnModel().getColumn(1).setCellEditor(et);
        table.getColumnModel().getColumn(0).setCellEditor(et);
        
        for (int i = 0; i < 5; i++) {
            dtm.addRow(new Object[]{i,1.5+i});
        }    
        
        
        table.setPreferredScrollableViewportSize(new Dimension(123, 123));
        this.add(new JScrollPane(table));
        
    }
    private void display() {
        JFrame f = new JFrame("Test Table");
        f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        f.add(this);
        f.pack();
        f.setLocationRelativeTo(null);
        f.setVisible(true);
    }
    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                new test().display();
            }
        });
    } 
    
    
    
    
    protected class CustomTableCellEditor  extends AbstractCellEditor implements TableCellEditor {
     
         private JTable table;
         JTextField component = new JTextField();
        public CustomTableCellEditor(JTable table) {
            this.table = table;
        }
        public boolean stopCellEditing() {
            
            boolean ans = super.stopCellEditing();            
            return ans;
        }
        @Override
        public void cancelCellEditing() {
            super.cancelCellEditing();
        }
        @Override
        public Object getCellEditorValue() {
            return component.getText();        
        }
        @Override
        public Component getTableCellEditorComponent(JTable arg0, Object value,
                boolean arg2, int arg3, int arg4) {
            component.setText(value.toString());
            return component;
        }
     }
}

您模型的getColumnClass()用于列1返回Float.class,因此您的getCellEditorValue()的实现应返回相同类型的值:

@Override
public Object getCellEditorValue() {
    return Float.valueOf(component.getText());        

作为替代方案,您可以按类别指定编辑器:

CustomTableCellEditor et = new CustomTableCellEditor(table);
table.setDefaultEditor(Float.class, et);

最新更新