我在调整包含围绕TableCell项目的文本项的TableView时遇到问题。调整大小后,隐藏的值会调整大小,但可见项不会重新计算文本换行。
红色框中的推文在调整大小时被隐藏,并按预期调整文本包装。在调整大小阶段,可以看到方框上方的推文仍然有旧的包装。
以下是调整大小阶段的代码。
fxSearchResultsTableTweet.setCellFactory(new Callback<TableColumn<Status, String>, TableCell<Status, String>>() {
@Override
public TableCell<Status, String> call(TableColumn<Status, String> arg0) {
return new TableCell<Status, String>() {
private Text text;
@Override
public void updateItem(String item, boolean empty) {
super.updateItem(item, empty);
if (!isEmpty()) {
text = new Text(item.toString());
text.setWrappingWidth(fxSearchResultsTableTweet.getWidth());
this.setWrapText(true);
setGraphic(text);
}
}
};
}
});
}
非常感谢任何帮助。
答案 0 :(得分:15)
这更接近,但不是很好:
textCol.setCellFactory(new Callback<TableColumn<Status, String>, TableCell<String, String>>() {
@Override
public TableCell<Status, String> call(
TableColumn<Status, String> param) {
TableCell<Status, String> cell = new TableCell<>();
Text text = new Text();
cell.setGraphic(text);
cell.setPrefHeight(Control.USE_COMPUTED_SIZE);
text.wrappingWidthProperty().bind(cell.widthProperty());
text.textProperty().bind(cell.itemProperty());
return cell ;
}
});
在2.2中,当您向表中添加新项目时显示错误的高度,然后在调整大小时,单元格的大小正确。在8中它几乎是完美的,在添加第一个项目之后似乎失败了(至少在我的模型中)。
如评论中所述,
textCol.setCellFactory(tc -> {
TableCell<Status, String> cell = new TableCell<>();
Text text = new Text();
cell.setGraphic(text);
cell.setPrefHeight(Control.USE_COMPUTED_SIZE);
text.wrappingWidthProperty().bind(textCol.widthProperty());
text.textProperty().bind(cell.itemProperty());
return cell ;
});
似乎效果更好。
答案 1 :(得分:0)
只需在列的每个表上添加单元格工厂即可。 它应该在将数据添加到表视图之前添加。 对我来说很好。
yourTableColumn.setCellFactory(param -> {
return new TableCell<YourDataClass, String>() {
@Override
protected void updateItem(String item, boolean empty) {
super.updateItem(item, empty);
if (item == null || empty) {
setText(null);
setStyle("");
} else {
Text text = new Text(item);
text.setStyle("-fx-text-alignment:justify;");
text.wrappingWidthProperty().bind(getTableColumn().widthProperty().subtract(35));
setGraphic(text);
}
}
};
});