Java Jtable-插入符号不';在cell StartEdit+;请求焦点()

Java Jtable-插入符号不';在cell StartEdit+;请求焦点(),java,swing,jtable,Java,Swing,Jtable,我有一个自定义的TableCellEditor/AbstractCellEditor设置,这样当双击单元格或按下空格键时,它就会进入编辑模式 class TextAreaCellEditor extends AbstractCellEditor implements TableCellEditor { JComponent component = new JTextArea(); @Override public boolean isCellE

我有一个自定义的TableCellEditor/AbstractCellEditor设置,这样当双击单元格或按下空格键时,它就会进入编辑模式

class TextAreaCellEditor extends AbstractCellEditor implements TableCellEditor {

        JComponent component = new JTextArea();

        @Override
        public boolean isCellEditable(EventObject e) {
            GenInput inp = new GenInput();
            if (super.isCellEditable(e)) {
                if (e instanceof MouseEvent) {
                    MouseEvent me = (MouseEvent) e;
                    return me.getClickCount() >= 2;
                }
                if (e instanceof KeyEvent) {
                    KeyEvent ke = (KeyEvent) e;
                    return ke.getKeyCode() == inp.spacebar; //'inp' is my own class that acts as a reference for keycodes
                }
            }
            return false;
        }
       ...
这两个命令都起作用,并激活StartEdit,这意味着接下来将执行以下代码:

@Override
public Component getTableCellEditorComponent(JTable table, Object value, boolean isSelected,
        int rowIndex, int vColIndex) {

    ((JTextArea) component).setText("");
    ((JTextArea) component).setWrapStyleWord(true);
    ((JTextArea) component).setLineWrap(true);
    ((JTextArea) component).requestFocus();
    ((JTextArea) component).addKeyListener(new KeyListener() {
    ...
工作部分:无论我是否包含“((JTextArea)component).requestFocus();”,当我双击它时,完全进入编辑模式,即插入符号开始闪烁,当我按下“向上”或“向下”时,插入符号在多行文本框中上下移动,而不是跳到下一行

问题:但是,当我按下空格键时,它会进入一种“部分”编辑模式;结果是插入符号不会闪烁,虽然我可以在框中键入单词,但如果我按“向上”/“向下”,它将跳转到上一行/下一行

当我开始通过空格键编辑时,如何使插入符号出现(即进入“完全编辑模式”,而不是我描述的“部分编辑模式”)

编辑:“((JTextArea)组件).getCaret().setVisible(true);”使插入符号显示,但不会改变它处于部分编辑模式的事实,因此我仍然无法在不失去焦点的情况下按上/下键。

解决方案如下:

表.setUrrendersFocusonKeystroke(真)

背景:

@Override
        public Component getTableCellEditorComponent(JTable table, Object value, boolean isSelected,
                int rowIndex, int vColIndex) {

            table.setSurrendersFocusOnKeystroke(true);
            ((JTextArea) component).setText("");
            ((JTextArea) component).setWrapStyleWord(true);
            ((JTextArea) component).setLineWrap(true);
            ((JTextArea) component).setFocusable(true);
对我来说很好

import java.awt.Component;
import java.awt.EventQueue;
import java.awt.event.KeyEvent;
import java.awt.event.MouseEvent;
import java.util.EventObject;
import javax.swing.AbstractCellEditor;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextArea;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableCellEditor;

public class Test {

    public static void main(String[] args) {
        new Test();
    }

    public Test() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                    ex.printStackTrace();
                }

                DefaultTableModel model = new DefaultTableModel(10, 1);
                JTable table = new JTable(model);
                table.setDefaultEditor(Object.class, new TextAreaCellEditor());
                table.setRowHeight(20);

                JFrame frame = new JFrame("Testing");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.add(new JScrollPane(table));
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    class TextAreaCellEditor extends AbstractCellEditor implements TableCellEditor {

        JTextArea component = new JTextArea();

        @Override
        public boolean isCellEditable(EventObject e) {
            if (super.isCellEditable(e)) {
                if (e instanceof MouseEvent) {
                    MouseEvent me = (MouseEvent) e;
                    return me.getClickCount() >= 2;
                }
                if (e instanceof KeyEvent) {
                    KeyEvent ke = (KeyEvent) e;
                    return ke.getKeyCode() == KeyEvent.VK_SPACE;
                }
            }
            return false;
        }

        @Override
        public Component getTableCellEditorComponent(JTable table, Object value, boolean isSelected,
                                                                                                 int rowIndex, int vColIndex) {

            ((JTextArea) component).setText("");
            ((JTextArea) component).setWrapStyleWord(true);
            ((JTextArea) component).setLineWrap(true);
            return  component;
        }

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

也许你的代码中有别的东西在搞乱它。考虑提供一个说明你的问题的方法。这不是一个代码转储,而是您正在做的一个示例,它突出了您所遇到的问题。这将减少混乱和更好的响应

基于我有限的测试,它工作正常。当
JTable
请求
getTableCellEditorComponent
时,该组件显然没有在屏幕上实现,因此调用
requestFocus
没有任何效果(但无论如何都应该调用
requestFocusInWindow
)。你在
JTextArea
@MadProgrammer上使用
KeyListener
,这也让我感到害怕。使用KeyListener有什么问题?当使用JTextArea作为CellEditor时,有没有更好的方法让它在“回车”结束编辑?否则,它只会转到下一行而不是下一个单元格,而不会结束编辑。实际上,我试着用表而不是文本区域来搞乱,这解决了我的问题:“table.setUrrendersFocusonKeystroke(true);”和-你必须记住,
JTextArea
已经对[Enter]有了定义的响应您知道需要覆盖的键“inp”是我自己的类,用作键代码的引用-为什么?不要重新发明轮子。只要使用
KeyEvent.VK_SPACE
,就不需要另一个类和变量名。