Я новичок в JavaFX и ControlsFX.
Я пытаюсь создать очень простой SpreadsheetView, используя библиотеку ControlsFX. Ниже приведена функция для заполнения и создания SpreadsheetView:
private fun spreadSheetFunc() : SpreadsheetView {
val rowCount = 15
val columnCount = 10
val grid = GridBase(rowCount, columnCount)
val rows = FXCollections.observableArrayList<ObservableList<SpreadsheetCell>>()
var list = FXCollections.observableArrayList<SpreadsheetCell>()
list.add(SpreadsheetCellType.STRING.createCell(0, 0, 1, 1, "row0-col0"))
list.add(SpreadsheetCellType.STRING.createCell(0, 1, 2, 1, "row0-col1"))
list.add(SpreadsheetCellType.STRING.createCell(0, 2, 1, 1, "row0-col2"))
rows.add(list)
list = FXCollections.observableArrayList()
list.add(SpreadsheetCellType.STRING.createCell(1, 0, 1, 1, "row1-col0"))
//commenting row1-col1 as row0-col1 has a rowspan of 2
//list.add(SpreadsheetCellType.STRING.createCell(1, 1, 1, 1, "row1-col1"))
list.add(SpreadsheetCellType.STRING.createCell(1, 2, 1, 1, "row1-col2"))
rows.add(list)
list = FXCollections.observableArrayList()
list.add(SpreadsheetCellType.STRING.createCell(2, 0, 1, 1, "row2-col0"))
list.add(SpreadsheetCellType.STRING.createCell(2, 1, 1, 1, "row2-col1"))
list.add(SpreadsheetCellType.STRING.createCell(2, 2, 1, 1, "row2-col2"))
rows.add(list)
list = FXCollections.observableArrayList()
list.add(SpreadsheetCellType.STRING.createCell(3, 0, 1, 1, "row3-col0"))
list.add(SpreadsheetCellType.STRING.createCell(3, 1, 1, 1, "row3-col1"))
list.add(SpreadsheetCellType.STRING.createCell(3, 2, 1, 1, "row3-col2"))
rows.add(list)
grid.setRows(rows)
return SpreadsheetView(grid)
}
При запуске получаю следующую ошибку:
java.lang.IndexOutOfBoundsException: индекс: 2, размер: 2 в java.util.ArrayList.rangeCheck(ArrayList.java:653)
Я знаю, что это происходит, потому что я не добавляю никакого значения для rowIndex=1 colIndex=1 (см. закомментированную строку)... но это то, что я хочу.
row0-col1 has a rowspan of 2
, что должно означать, что даже если мой row1-col1 отсутствует, проблем быть не должно.
Почему ControlsFX не позаботится об этом автоматически?
Если я раскомментирую эту строку, я получу следующий вывод:
Редактировать 1:
Кроме того, я обнаружил еще одну проблему, когда colspan/rowspan занимает весь столбец/строку в SpreadsheetView, а затем, когда вы нажимаете клавишу со стрелкой для перехода к ячейкам, вы получаете сообщение об ошибке:
Вышеупомянутая ситуация возникает, когда вы нажимаете клавишу со стрелкой вправо (даже если это не ячейка справа)