3

我正在为我的 TableColumns 创建一个自定义标题,它是列的标签加上一个允许用户执行搜索的 TextField。我正在设置列标题,如下所示:

getColumns().addListener(new ListChangeListener<TableColumn<S, ?>>() {
        @Override
        public void onChanged(final ListChangeListener.Change<? extends TableColumn<S, ?>> change) {
            while (change.next()) {
                Label label;
                TextField search;
                VBox graphic;
                for (TableColumn<S, ?> column : change.getAddedSubList()) {
                    label = new Label(column.getText());
                    search = new TextField();
                    graphic = new VBox();
                    graphic.getStyleClass().add("k-column-graphic");
                    graphic.getChildren().addAll(label, search);
                    column.setGraphic(graphic);
                }
            }
        }
    });

所以列的图形就是显示的内容。我正在使用以下 CSS(图形本身有一个“k-column-graphic”CSS 类,而 TableView 有一个“k-table-view”CSS 类)

/** Hide default text label in KTableView */
.k-table-view .column-header > .label  {
    -fx-content-display: graphic-only;
}

.k-column-graphic {
    -fx-alignment: center-left;
    -fx-spacing: 5;
    -fx-padding: 2;
}

这很好用,但我还允许通过启用TableView.setTableMenuButtonVisible(true);属性来隐藏列,该属性添加了一个按钮来轻松隐藏列。

每当我尝试隐藏一列时,它都会成功隐藏,但图形(标签/文本字段)仍然存在。两者的宽度似乎都为 0 或 1,并且非常小,但您仍然可以看到它们。

全部可见

网站隐藏

如何通过 CSS 或在我的代码中的某个位置,将它隐藏到 TableColumn 的图形节点也将隐藏的位置?

4

1 回答 1

1

当您切换CheckMenuItem显示/隐藏列时,您的自定义控件不会自动更改其VisibleProperty. 所以你需要做的就是简单地将VisibleProperty你自己的控件绑定到TableColumn'sVisibleProperty上。

以下示例基于您的代码。希望它能有所帮助。

    getColumns().addListener(new ListChangeListener<TableColumn<S, ?>>() {
        @Override
        public void onChanged(final ListChangeListener.Change<? extends TableColumn<S, ?>> change) {
            while (change.next()) {
                Label label;
                TextField search;
                VBox graphic;
                for (TableColumn<S, ?> column : change.getAddedSubList()) {
                    label = new Label(column.getText());
                    search = new TextField();
                    graphic = new VBox();
                    graphic.getStyleClass().add("k-column-graphic");
                    graphic.getChildren().addAll(label, search);
                    column.setGraphic(graphic);

                    /* ======= add the following two lines ============== */
                    label.visibleProperty().bind(column.visibleProperty());
                    search.visibleProperty().bind(column.visibleProperty());
                }
            }
        }
    });
于 2014-08-24T03:25:35.317 回答