TableView - 单元格的上移和下移功能

Posted

技术标签:

【中文标题】TableView - 单元格的上移和下移功能【英文标题】:TableView - Move up and Move down functionality of a cell 【发布时间】:2015-05-05 09:18:07 【问题描述】:

我有一个TableView 的情况。我正在尝试实现一个允许向上或向下移动单元格的功能。向上或向下移动单元格(带有单元格内容)后,我想将焦点更改为单元格的新位置。

问题是它不会更改到新位置。由于某种原因,它停留在原来选定的单元格位置。

这是用于上移、下移和改变焦点的代码:

我正在尝试移动单个选定的单元格。

public class TableController

    private ObservableList<SimpleStringProperty> observablePrnPropertyData;

    @FXML
    private TableView<SimpleStringProperty> table;
    @FXML
    private TableColumn<SimpleStringProperty, String> data;        

    @FXML
    private void initialize()
    
        this.data.setCellValueFactory(cellData -> cellData.getValue());
        this.data.setCellFactory(event -> new EditCell(this.observablePrnPropertyData, this.table));
    

    public void display(final PrnProperty prnProperty)
    
        this.observablePrnPropertyData = PrnPropertyUtil.getObservableDataFromPrnProperty(prnProperty);
        this.table.setItems(this.observablePrnPropertyData);
    


    private final class EditCell extends TableCell<SimpleStringProperty, String>
    
        @Override
        public void updateItem(String item, boolean empty)
        
            super.updateItem(item, empty);

            if (empty)
            
                this.setText(null);
                this.setGraphic(null);
            
            else
            
                this.setUpContextMenu();

                this.setText(this.getString());
                this.setGraphic(null);
            
        

        private void setUpContextMenu()
        
            // Context menu
            ContextMenu contextMenu = new ContextMenu();

            // context menu Move up
            this.moveUp = new MenuItem("Move up");
            this.moveUp.setOnAction(event -> this.moveUp(this.table, this.observablePrnPropertyData));
            contextMenu.getItems().add(this.moveUp);

            // Context menu for move down
            this.moveDown = new MenuItem("Move down");
            this.moveDown.setOnAction(event -> this.moveDown(this.table, this.observablePrnPropertyData));
            contextMenu.getItems().add(this.moveDown);

            // Add context menu
            this.setContextMenu(contextMenu);
        

        public void moveUp(final TableView<?> table, ObservableList listToManipulate)
        
            final int selectedIndex = table.getSelectionModel().getSelectedIndex();

            final Object removeItem = listToManipulate.remove(selectedIndex);

            final int newIndex = selectedIndex - 1;
            listToManipulate.add(newIndex, removeItem);
            this.changeTableCellFocus(table, newIndex);
        

        public void moveDown(final TableView<?> table, ObservableList listToManipulate)
        
            final int selectedIndex = table.getSelectionModel().getSelectedIndex();

            final Object remove = listToManipulate.remove(selectedIndex);

            final int newIndex = selectedIndex + 1;
            listToManipulate.add(newIndex, remove);
            this.changeTableCellFocus(table, newIndex);
        

        public void changeTableCellFocus(final TableView<?> table, final int focusIndex)
        
            table.requestFocus();
            table.getSelectionModel().clearAndSelect(focusIndex);
            table.getFocusModel().focus(focusIndex);
        
    

如果有人能给出一个可行的例子,那就太好了。我真的很想知道我做错了什么。

【问题讨论】:

您能否提供更多有关如何创建表格的代码。这很重要,因为目前我无法从您的代码中判断您是要移动单个单元格还是整行。此外,数据绑定很重要,因此如果您在其他位置有它,也请添加该代码。 我对代码进行了一些更改以包含更多信息。 您的代码将移动整行,而不仅仅是一个单元格(尽管现在看起来您只有一列)。这是一个完整的 hack,但请尝试将对 changeTableCellFocus(...) 的调用封装在 Platform.runLater(...) 中。 我已经尝试过Platform.runLater(...),但我仍然遇到同样的问题。整行向上移动,但焦点不会更改到新行位置。 javafx-1 "= javafx script is notlevant" 在这里和所有其他 javafx 问题中! 【参考方案1】:

对于您的情况,使用此代码可以正常工作,很简单,您必须首先获取所选索引,将项目移动到下一个(或上一个)行,然后选择这个新行。

void upClicked()
    if(table.getSelectionModel().getSelectedItem() != null) // check if the user really selected a row in the table
    
        if(table.getSelectionModel().getSelectedIndex() != 0) // if the row first one so do nothing
        
            int index = table.getSelectionModel().getSelectedIndex(); // get the selected row index
            SimpleStringProperty x = table.getSelectionModel().getSelectedItem(); // get the selected item
            table.getItems().set(index, table.getItems().get(index-1)); // move the selected item up
            table.getItems().set(index-1, x); // change the row with the item in above
            table.getSelectionModel().select(index-1); // select the new row position
        
    


void downClicked()
    if(table.getSelectionModel().getSelectedItem() != null)
    
        if(table.getSelectionModel().getSelectedIndex() != table.getItems().size()-1) // if the row is in last so dont do nothing
        
            int index = table.getSelectionModel().getSelectedIndex();
            SimpleStringProperty x = table.getSelectionModel().getSelectedItem();
            table.getItems().set(index, table.getItems().get(index+1));
            table.getItems().set(index+1, x);
            table.getSelectionModel().select(index+1);
        
    

【讨论】:

【参考方案2】:

如果您只需要关注下一行和上一行,您可以尝试:table.getFocusModel().focusNext() 和 .focusPrevious(),如下所述:http://docs.oracle.com/javafx/2/api/javafx/scene/control/FocusModel.html

【讨论】:

我已经尝试过了,但我仍然遇到同样的问题。我一定做错了什么,但不确定是什么。如果有人能给出一个可行的例子,那就太好了。

以上是关于TableView - 单元格的上移和下移功能的主要内容,如果未能解决你的问题,请参考以下文章

tableview 单元格我们如何快速调整单元格的大小以及图像和标签

tableView 单元格的正常和选定状态的不同象形图

自定义 Tableview 单元格的问题

iOS:访问下一个 Tableview 单元格的按钮

带有两个自定义单元格的 TableView 导致单元格重用问题(Swift 4)

使标签等于 TableView 单元格的标题和副标题