我有一个视图,在这个视图中有几个tableview,但是假设我有两个表。当我重新排列第一个表中的列时(通过使用拖放),我想在第二个表中做同样的事情。我试过,但我 IllegalStateException: Duplicate TreeTableColumns detected in TreeTableView columns list with titles ''
这是我尝试过的:
private void handleDragAndDrop() {
firstTable.getColumns().addListener((ListChangeListener<? super TableColumn<?, ?>>) c -> {
while (c.next()) {
List<String> addedIDs = c.getAddedSubList()
.stream()
.map(TableColumn::getId)
.collect(Collectors.toList());
Map<String, String> changedIds = getChangedIds(addedIDs);
changedIds.entrySet()
.stream()
.reduce((firstEntry, lastEntry) -> lastEntry)
.ifPresent(entry-> reorderTheSecondTable(secondTable.getColumns(),entry.getValue(),
entry.getKey()));
}
});
}
private Map<String, String> getChangedIds(List<String> iDs) {
return new LinkedHashMap<>(iDs.stream()
.skip(1) // I don't need the first column, that will be never reordered.
.filter(id -> !id.equals(String.valueOf(iDs.indexOf(id)))) // I need only the changed id-index pairs.
.collect(Collectors.toMap(i -> String.valueOf(iDs.indexOf(i)), Function.identity())));
}
private void reorderTheSecondTable(ObservableList<? extends TableColumnBase<?, ?>> list, String start, String end) {
Collections.rotate(list.subList(Integer.valueOf(start), Integer.valueOf(end) + 1), 1);
}
列的ID来自 1
至 table.getColumns().size()-1
(0是不可变列)
异常在第行抛出 Collections.rotate(...
我不知道这是不是正确的方法,但我没有找到任何更好的解决办法,甚至这不是一个解决办法,因为它不工作。
1条答案
按热度按时间uqjltbpv1#
你可以这样做:
这将创建“记住”每个表中列的原始顺序的列表。侦听器只是在第一个表的原始列列表中查找索引,并为第二个表的列创建与该顺序对应的列表。此代码假定两个表的列数相同。
这是一个sscce: