Tengo extensión de extensión
''
BarChartView {
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
}
}
''
Y la aplicación falla aquí
for j in 0 ..< Int(ceil(Double(dataSet.entryCount) * animator.phaseX)) // Crash here
{
guard let e = dataSet.entryForIndex(j) as? BarChartDataEntry else { continue }
Error fatal: no se puede formar el rango con upperBound <lowerBound
(lldb) po dataSet.entryCount
12
(lldb) po animator.phaseX
-0.085005447941268492
Resuelve este problema
Creo que es posible que en tu proyecto haya una gran función que lleve tiempo.
se acabó el tiempo
la solucion
DispatchQueue.main.async(execute: {() -> Void in
self.animate(xAxisDuration: 2.0, yAxisDuration: 2.0, easingOption: .easeInBack)
})
Creo que sí,
for j in 0 ..< Int(ceil(Double(dataSet.entryCount) * animator.phaseX))
cambiar para
for j in stride(from: 0, to: Int(ceil(Double(dataSet.entryCount) * animator.phaseX)), by: 1)
@PrashantKT Tengo el mismo problema y el fragmento que @txoan ha publicado está funcionando, pero sería genial si alguien pudiera verificar si la solución no presenta nuevos errores o cualquier otro problema. @jjatie @ liuxuan30