ControlsFX SpreadsheetView rowspan IndexOutOfBoundsException

时间:2016-12-30 07:40:26

标签: javafx spreadsheet kotlin controlsfx

我是JavaFX和ControlsFX的新手。

我正在尝试使用ControlsFX库创建一个非常基本的SpreadsheetView。以下是填充和创建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:Index:2,Size:2 at   java.util.ArrayList.rangeCheck(ArrayList.java:653)

我知道它发生了,因为我没有为rowIndex = 1 colIndex = 1添加任何值(参见注释掉的行)......但这就是我想要的。

row0-col1 has a rowspan of 2这意味着即使我的row1-col1不存在,也应该没有任何问题。

为什么ControlsFX不会自动处理这个?

如果我取消注释该行,我会得到以下输出:

enter image description here

修改1:

另外,我发现了另一个问题,当一个colspan / rowspan占用SpreadsheetView中的整个列/行,然后当按下箭头键导航到单元格时会出现错误:

enter image description here

当您按右箭头键时出现上述情况(即使它们不是右侧的单元格)

1 个答案:

答案 0 :(得分:1)

让我道歉,因为没有详细记录如何在SpreadsheetView中进行跨度。我将更新文档。

如果要跨越,则必须在跨度内的每个单元格中放置相同的单元格。 所以要么你建立自己的细胞,然后在每个地方。在您的情况下,您将在第0行第1列和第1行第1列中添加相同的单元格。 或者您可以保留代码,只需在网格上调用方法spanRow即可。此方法将自动获取您的单元格并相应地放置它。

关于第二个问题,请将其提交给我们的问题跟踪器,以便我们对其进行修复:https://bitbucket.org/controlsfx/controlsfx/issues?status=new&status=open

如果您有关于SpreadsheetView的其他问题,请考虑在我们的Google论坛中发帖,我们会收到通知:http://groups.controlsfx.org