Java Jtable-插入符号不';在cell StartEdit+;请求焦点()
我有一个自定义的TableCellEditor/AbstractCellEditor设置,这样当双击单元格或按下空格键时,它就会进入编辑模式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
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
,就不需要另一个类和变量名。