我在互联网上看到了一些关于向TableView添加行的示例,例如使用Oracle文档中的Person类。
但是我的列数是可变的,所以我不能绑定到一个Person(或任何其他)bean业务对象。
Oracle的示例继续展示如何将列绑定到属性名称,但是它只展示了如何添加列而没有添加行。
我的问题是,有人能指引我一个动态添加任意列和/或行的JavaFX 8 TableView Hello World示例吗?
我在互联网上看到了一些关于向TableView添加行的示例,例如使用Oracle文档中的Person类。
但是我的列数是可变的,所以我不能绑定到一个Person(或任何其他)bean业务对象。
Oracle的示例继续展示如何将列绑定到属性名称,但是它只展示了如何添加列而没有添加行。
我的问题是,有人能指引我一个动态添加任意列和/或行的JavaFX 8 TableView Hello World示例吗?
List<String>
(例如)作为数据类型,并将单元格值工厂设置为一个索引到列表的回调即可。例如,这将创建一个TableView<List<String>>
,它是由任意的制表符分隔文本文件构建而成。文件中的并非所有行都需要有相同数量的元素(它会用空格填充)。(它不支持转义制表符等):public TableView<List<String>> readTabDelimitedFileIntoTable(Path file) throws IOException {
TableView<List<String>> table = new TableView<>();
Files.lines(file).map(line -> line.split("\t")).forEach(values -> {
// Add extra columns if necessary:
for (int i = table.getColumns().size(); i < values.length; i++) {
TableColumn<List<String>, String> col = new TableColumn<>("Column "+(i+1));
col.setMinWidth(80);
final int colIndex = i ;
col.setCellValueFactory(data -> {
List<String> rowValues = data.getValue();
String cellValue ;
if (colIndex < rowValues.size()) {
cellValue = rowValues.get(colIndex);
} else {
cellValue = "" ;
}
return new ReadOnlyStringWrapper(cellValue);
});
table.getColumns().add(col);
}
// add row:
table.getItems().add(Arrays.asList(values));
});
return table ;
}
这个示例代码有点笨重,但似乎可以正常工作:
TableView table = new TableView<>();
private char nextChar = 'A';
private void addColumn(TableView table) {
String mapChar = String.valueOf(nextChar++);
TableColumn<Map, String> column = new TableColumn<>("Class " + mapChar);
column.setCellValueFactory(new MapValueFactory(mapChar));
column.setMinWidth(130);
column.setCellFactory(cellFactoryForMap);
table.getColumns().add(column);
}
private void addRow(TableView table) {
ObservableList<Map> allData = table.getItems();
int offset = allData.size();
Map<String, String> dataRow = new HashMap<>();
for (int j = 0; j < table.getColumns().size(); j++) {
String mapKey = Character.toString((char) ('A' + j));
String value1 = mapKey + (offset + 1);
dataRow.put(mapKey, value1);
}
allData.add(dataRow);
}
}