动态显示DatePicker
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了动态显示DatePicker相关的知识,希望对你有一定的参考价值。
我正在编写一个JavaFX应用程序,它显示了StringProperty
和ObjectPropery<LocalDate>
值的表。当我深入研究表格如何工作时,似乎我不能使用DatePicker
作为单元格,所以我打算做的是将日期显示为字符串,但是当用户尝试编辑该单元格时,我捕获该事件并显示动态DatePicker
将接受新的日期值并更新单元格。
现在,我无法让这个动态的DatePicker
显示出来。
JavaFX的:
<TableView fx:id="tableView" editable="true" GridPane.columnIndex="0" GridPane.rowIndex="1">
<columns>
...
<TableColumn fx:id="recDate" onEditStart="#handleChangeDate" prefWidth="100.0" text="Received Date">
<cellValueFactory>
<PropertyValueFactory property="recDate" />
<!-- <DatePicker fx:id="recDatePicker" /> -->
</cellValueFactory>
</TableColumn>
...
Java 8:
@FXML
private void handleChangeDate(CellEditEvent<MissionItem, LocalDate> e) {
final DatePicker dp = new DatePicker(e.getOldValue());
dp.setDisable(false);
dp.setOnAction(event -> {
LocalDate date = dp.getValue();
System.out.println("Selected date: " + date);
});
Platform.runLater(dp::show);
dp.show(); //redundant. Still doesn't work.
System.out.println("fired event");
}
我能够看到fired event
然而DatePicker
永远不会出现。
我的目标是:
- 将表显示为一组字符串/ LocalDates
- 假设一个单元格本身不能是一个DatePicker,那么很好的事件处理程序,当用户想要编辑日期单元格时,动态DatePicker会显示,接受用户输入,并且值会更新。
- 确保此比例为1000行。
答案
要自定义列的单元格,您需要在此列的TableCell
中创建适当的cellFactory
s:
public class DatePickerTableCell<T> extends TableCell<T, LocalDate> {
private final DatePicker datePicker;
private boolean listening = true;
// listener for changes in the datepicker
private final ChangeListener<LocalDate> listener = (observable, oldValue, newValue) -> {
if (listening) {
listening = false;
TableColumn<T, LocalDate> column = getTableColumn();
EventHandler<TableColumn.CellEditEvent<T, LocalDate>> handler = column.getOnEditCommit();
if (handler != null) {
// use TableColumn.onEditCommit if there is a handler
handler.handle(new TableColumn.CellEditEvent<>(
(TableView<T>) getTableView(),
new TablePosition<T, LocalDate>(getTableView(), getIndex(), column),
TableColumn.<T, LocalDate>editCommitEvent(),
newValue
));
} else {
// otherwise check if ObservableValue from cellValueFactory is
// also writable and use in that case
ObservableValue<LocalDate> observableValue = column.getCellObservableValue((T) getTableRow().getItem());
if (observableValue instanceof WritableValue) {
((WritableValue) observableValue).setValue(newValue);
}
}
listening = true;
}
};
public DatePickerTableCell() {
this.datePicker = new DatePicker();
this.datePicker.valueProperty().addListener(listener);
}
@Override
protected void updateItem(LocalDate item, boolean empty) {
super.updateItem(item, empty);
if (empty) {
listening = false;
setGraphic(null);
} else {
listening = false;
setGraphic(this.datePicker);
this.datePicker.setValue(item);
listening = true;
}
}
public static <E> Callback<TableColumn<E, LocalDate>, TableCell<E, LocalDate>> forTableColumn() {
return column -> new DatePickerTableCell<>();
}
}
请注意,此类不会对“正常”编辑状态做出反应。它始终处于编辑状态。但是,它确实调用onEditCommit
处理程序来启用对非可观察属性的处理编辑。
可以通过fxml使用添加工厂
<TableColumn fx:id="recDate" prefWidth="100.0" text="Received Date">
<cellValueFactory>
<PropertyValueFactory property="recDate" />
</cellValueFactory>
<cellFactory>
<DatePickerTableCell fx:factory="forTableColumn"/>
</cellFactory>
</TableColumn>
(需要和适当的导入指令包含在fxml中。)
以上是关于动态显示DatePicker的主要内容,如果未能解决你的问题,请参考以下文章
如何从我的 DatePicker 片段中传输格式化的日期字符串?