如何在JavaFX 2中禁用表格单元格进行编辑

时间:2013-02-01 17:02:37

标签: javafx-2 javafx

在JavaFX 2中,我想禁用列中的某些单元格进行编辑。

的内容
TableModel.isCellEditable(row, col)
在Swing中

我需要行中的项目来决定单元格是否可编辑,单元格值是否足够。

我设法编写的代码是:

TableView<FilterItem> localTableView = new TableView<FilterItem>() {
    public void edit(int paramInt, TableColumn<FilterItem, ?> paramTableColumn) {
        if (paramInt >= 0) {
            FilterItem item = getItems().get(paramInt); //get item in the row
                if (!item.isPropagated()) {             //condition
                    return;
                }
        }
        super.edit(paramInt, paramTableColumn);
    }

};

问题在于没有视觉线索表明某些项目已被禁用以进行编辑。

设置单元工厂是我尝试的第一件事,但我无法访问更新单元格方法中的行数据:

localValueCol.setCellFactory(
    new Callback<TableColumn<FilterItem, String>, TableCell<FilterItem, String>>() {

        @Override
        public TableCell<FilterItem, String> call(TableColumn<FilterItem, String> paramTableColumn) {
            return new TextFieldTableCell<FilterItem, String>() {
                @Override
                public void updateItem(String s, boolean b) {
                    super.updateItem(s, b);
                    // it is possible set editable property here, 
                    // but other cells are not available to make a decision
                }


            };
        }

    });

1 个答案:

答案 0 :(得分:2)

似乎

TableRow row = getTableRow();
FilterItem item = (FilterItem) row.getItem();

可在单元格中完成工作。 完整的方法如下:

@Override
public void updateItem(T t, boolean empty) {
    super.updateItem(t, empty);
    TableRow row = getTableRow();
    if (row != null) {
        FilterItem item = (FilterItem) row.getItem();
        //Test for disable condition
        if (item != null && item.getRating() < 10) {
            setDisable(true);
            setEditable(false);
            this.setStyle("-fx-text-fill: grey");
        }
    }
}