1

我有一个包含复选框的 JTable。我的应用程序的构建方式是,每当编辑任何条目时,背景都会发生变化,以显示条目处于编辑状态。我已经用鼠标设置了它,但是当添加一个 KeyListener 来捕捉键盘上按下空格时,keyReleased 方法仅在 Space 被按住更长时间时触发,并且复选框快速选择和取消选择。

当我使用 keyTyped 和 keyPressed 方法时,一切都很好,只是它落后了一步,因为输入到表中的新数据没有被捕获。

所以,我的问题是我怎样才能在桌子上按下空间时捕捉并收集桌子的所有当前值?

我正在使用 MVC 架构;这是我的控制:

public class UserInternalFrameController {

    UserInternalFrame gui = new UserInternalFrame();

    public UserInternalFrameController(ManagementGUI mainGui) {
        gui.getTableUserTransactionPermissions().addKeyListener(new KeyListener() {

            @Override
            public void keyTyped(KeyEvent e) {
                System.out.println("typed");
                // TODO Auto-generated method stub
                if (e.getKeyChar() == ' ') {
                    if (stateMachine == 2 || stateMachine == 4) {
                        JTable permTable = gui.getTableUserTransactionPermissions();
                        int noOfColumns = gui.getUserTransactionPermissionsHeader().length;
                        permListEdit = false;
                        for (int i = 0; i < permList.length; i++) {
                            for (int j = 0; j < noOfColumns; j++) {
                                if (!permList[i][j].equals(permTable.getValueAt(i, j))) {
                                    System.out.println("row" + i + "; column" + j + "; perList:" + permList[i][j] + "; transList: " + permTable.getValueAt(i, j));
                                    permListEdit = true;
                                }
                            }
                        }
                        if ((employeeCodeEdit || usernameEdit || passwordEdit || userIdEdit || subjectIdEdit || userStatusEdit || userRoleEdit || permListEdit) == false) {
                            gui.getPanelUser().setBackground(defaultBackgroundPanelUser);
                            gui.getTableUserTransactionPermissions().setBackground(Color.WHITE);
                            stateMachine = 2;
                            gui.getBtnSave().setEnabled(false);
                        } else {
                            gui.getPanelUser().setBackground(Color.decode("#f5deb3"));
                            gui.getTableUserTransactionPermissions().setBackground(Color.decode("#f5deb3"));
                            stateMachine = 4;
                            gui.getBtnSave().setEnabled(true);
                        }
                    }
                }
            }
        });
    }
}

相同的代码块可以很好地与鼠标 actionListener 配合使用,并且在添加到 keyPressed 方法时具有相同的延迟效果。keyReleased 似乎适用于除空格以外的所有其他按钮。

我的键盘很好。

任何帮助将不胜感激。

4

2 回答 2

3

如本示例所示,并在本教程中讨论,类型表列的默认渲染器和编辑器Boolean.classJCheckBox. 复选框的默认鼠标处理程序正常工作,默认键绑定space键。该UIManager属性Table.selectionBackground 将以设计者首选和用户期望的方式突出显示选定的单元格。

我鼓励您放弃显示的方法并使用默认值。

于 2012-05-08T01:42:52.017 回答
1

这个问题的答案相当简单。新手错误。这是我如何更新数据检索表的片段(来自 MVC 模式的控制器;gui 是视图实例)。

// update tableUserSearchResult
gui.setUserSearchTableData(tempList); 
gui.setUserSearchResultTableModel(new DefaultTableModel(
    gui.getUserSearchTableData(), gui.getUserSearchTableHeader()));
gui.getTableUserSearchResult().setModel(gui.getUserSearchResultTableModel());

我真的不知道为什么创建新DefaultTableModel实例会导致此错误,因为我将表的模型定义并设置为新实例。我想那...

但是,通过使用 的setDataVector方法DefaultTableModel,我能够DefaultTableModel正确更新(不创建)一个新实例,并且它工作得很好:

gui.setUserRolePermissionsData(userRolePermissionList);
gui.getUserRolePermissionsTableModel().setDataVector(
    gui.getUserRolePermissionsData(), gui.getUserRolePermissionsHeader());
gui.getTableUserRolePermissions().setModel(gui.getUserRolePermissionsTableModel());

这就是我在视图中声明对象的方式:

public class UserRoleInternalFrame extends JInternalFrame {
DefaultTableModel userRoleDocumentsPermissionsTableModel;
    Object [][] userRoleDocumentsPermissionsData;
    String[] userRoleDocumentsPermissionsHeader = {
        "Document", "Edit", "View", "Process", "Update"
    };
    private JTable tableDocumentPermissions;
    private JScrollPane scrollPaneDocumentPermissions;

...

this.userRolePermissionsTableModel = new DefaultTableModel(
    this.userRolePermissionsData, this.userRolePermissionsHeader);
tableUserRolePermissions = new JTable(this.userRolePermissionsTableModel){
    @Override // in order to render JCheckBox
    public Class getColumnClass(int c) {
        if (c == 1 || c == 2 || c == 3 || c == 4){
            return Boolean.class;
        } else {
            return String.class;
        }
    }
};

scrollPaneEntryTypePermissions.setColumnHeaderView(tableUserRolePermissions);
    scrollPaneEntryTypePermissions.setViewportView(tableUserRolePermissions);
于 2012-05-14T06:48:24.527 回答