Ich habe eine Erweiterungserweiterung
```
Balkendiagrammansicht {
private class BarChartFormatter: NSObject,IAxisValueFormatter {
var values : [String]
required init (values : [String]) {
self.values = values
super.init()
}
func stringForValue(_ value: Double, axis: AxisBase?) -> String {
return values[Int(value)]
}
}
func setChartValues (xAxisValues : [String] , values : [Double],label : String) {
var barChartDataEntries = [BarChartDataEntry]()
for i in 0..<values.count {
let dataEntry = BarChartDataEntry(x: Double(i), y: values[i])
barChartDataEntries.append(dataEntry)
}
let chartDataSet = BarChartDataSet(values: barChartDataEntries, label: label)
chartDataSet.colors = ChartColorTemplates.colorful()
let chartData = BarChartData(dataSet: chartDataSet)
let formatter = BarChartFormatter(values: xAxisValues)
let xAxis = XAxis()
xAxis.valueFormatter = formatter
self.xAxis.valueFormatter = xAxis.valueFormatter
self.xAxis.labelPosition = .bottom
self.data = chartData
// self.data?.notifyDataChanged()
// self.notifyDataSetChanged()
self.animate(xAxisDuration: 2.0, yAxisDuration: 2.0, easingOption: .easeInBack) // Cause crash
}
}
```
Und App stürzt hier ab
for j in 0 ..< Int(ceil(Double(dataSet.entryCount) * animator.phaseX)) // Crash here
{
guard let e = dataSet.entryForIndex(j) as? BarChartDataEntry else { continue }
Schwerwiegender Fehler: Range kann nicht mit UpperBound < LowerBound . gebildet werden
(lldb) po dataSet.entryCount
12
(lldb) po animator.phaseX
-0.085005447941268492
Bitte lösen Sie dieses Problem
Ich denke, es ist möglich, dass es in Ihrem Projekt eine große Funktion gibt, die Zeit braucht
Die Zeit ist um
la lösung
DispatchQueue.main.async(execute: {() -> Void in
self.animate(xAxisDuration: 2.0, yAxisDuration: 2.0, easingOption: .easeInBack)
})
Ich glaube schon,
for j in 0 ..< Int(ceil(Double(dataSet.entryCount) * animator.phaseX))
ändern für
for j in stride(from: 0, to: Int(ceil(Double(dataSet.entryCount) * animator.phaseX)), by: 1)
@PrashantKT Ich habe das gleiche Problem und das Snippet, das @txoan gepostet hat, funktioniert, aber es wäre großartig, wenn jemand überprüfen könnte, ob die Lösung keine neuen Fehler oder andere Probleme mit sich bringt. @jjatie @liuxuan30