我有一个包含许多自定义对象(val rolls: ObservableList<Roll>)的ObservableList。这些对象中的每一个都有一个val results: ObservableList<Pair<Int, Double>>。这些对表示一个可能的数字和此结果发生的机会。我想在BarChart中可视化这些对。Roll还包含系列的名称。结果、名称和滚动列表可以在以后更改(通过用户输入),并应反映在图表中。
Roll类的最小示例如下所示:
class Roll (
val results: ObservableList<Pair<Int, Double>>,
initialName: String
){
val nameProperty = SimpleStringProperty(initialName)
var name by nameProperty
}以下是我尝试过的内容:
barchart(x = CategoryAxis(), y = NumberAxis()) {
data = rolls.map { roll ->
XYChart.Series<String, Number>(roll.name, roll.results.map { (result, chance) ->
XYChart.Data<String, Number>(result.toString(), chance)
}.asObservable())
}.asObservable()
}这会成功地将数据映射到正确的表单并显示出来。当然,这种方法的问题是它不能反映对rolls或rolls中元素的更改。有没有办法做到这一点?
发布于 2019-10-16 19:08:10
我最终做的是在更新图表的列表上放置一个更改侦听器,并将更改侦听器放在Roll的所有相关属性上(这也会更新图表):
barchart(x = CategoryAxis(), y = NumberAxis()) {
animated = true
updateData(this)
rolls.forEach {
it.nameProperty.onChange { updateData(this) }
it.results.onChange { updateData(this) }
}
rolls.onChange {
updateData(this)
it.addedSubList.forEach {
it.nameProperty.onChange { updateData(this) }
it.results.onChange { updateData(this) }
}
}
}为此,我将问题中提到的数据转换函数放在一个单独的函数中:
fun updateData(chart: BarChart<String, Number>){
chart.data = rolls.map { roll ->
XYChart.Series<String, Number>(roll.name, roll.results.map { (result, chance) ->
XYChart.Data<String, Number>(result.toString(), chance)
}.asObservable())
}.asObservable()
}不过,这个解决方案感觉还是有些脏,所以如果有人知道一种更干净的方法,我会很感激的。
https://stackoverflow.com/questions/58392972
复制相似问题