繁体   English   中英

如何防止JTable单元在某些击键开始编辑?

[英]How to prevent JTable cell from starting editing on certain key strokes?

我在我的JTable中实现了撤销/重做功能,但我遇到了JTable的默认行为问题,它在任何按键开始时都会开始编辑单元格。

问题是它也开始编辑CTRL + ZCTRL + Y.

按下这两个键时如何防止单元格编辑?

注意:我有多个面板,在一个面板中有多个表,我尝试重写isCellEditable()但失败了。

此示例阻止在CTRL + ZCTRL + Y上编辑单元格。 它通过以下方式实现:

  1. 重写CellEditor.isCellEditable
  2. 检查传递的事件对象是否是KeyEvent的实例
  3. 如果是这样,并且按下的键是CTRL + ZCTRL + Y ,则返回false

import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.event.KeyEvent;
import java.util.EventObject;

import javax.swing.DefaultCellEditor;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.SwingUtilities;
import javax.swing.table.TableCellEditor;

public class JTableWithCtrlZ {
    private JTableWithCtrlZ( ) {}

    @SuppressWarnings("serial")
    private static JTable createTable( ) {
        return new JTable( 10, 10 ) {
            @Override
            public TableCellEditor getDefaultEditor( Class<?> columnClass ) {
                return new DefaultCellEditor( new JTextField( ) ) {
                    @Override
                    public boolean isCellEditable( EventObject anEvent ) {
                        if( anEvent instanceof KeyEvent ) {
                            KeyEvent ke = (KeyEvent) anEvent;
                            if( ( ke.getKeyCode( ) == KeyEvent.VK_Z || ke.getKeyCode( ) == KeyEvent.VK_Y ) &&
                                ( ke.getModifiersEx( ) & KeyEvent.CTRL_DOWN_MASK ) == KeyEvent.CTRL_DOWN_MASK )
                                return false;
                        }

                        return super.isCellEditable( anEvent );
                    }
                };
            }
        };
    }

    public static JFrame createFrame( ) {
        JPanel p = new JPanel( );
        p.setLayout( new BorderLayout( ) );
        p.add( new JScrollPane( createTable( ) ), BorderLayout.CENTER );
        p.setPreferredSize( new Dimension( 250, 150 ) );

        JFrame f = new JFrame( );
        f.setDefaultCloseOperation( JFrame.EXIT_ON_CLOSE );
        f.setContentPane( p );
        f.pack( );
        return f;
    }

    public static void main(String[] args) {
        SwingUtilities.invokeLater( new Runnable() {
            @Override
            public void run() {
                createFrame( ).setVisible( true );
            }
        });
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM