gpt4 book ai didi

IOS 图表 Y 轴未正确对齐 - 图表 Cocoa Pod

转载 作者:行者123 更新时间:2023-11-29 00:18:20 32 4
gpt4 key购买 nike

我目前正在使用 IOS 图表,该库的链接位于:Link

目前,图表左轴标签未代表其应有的内容。该图表当前已放大,以便可以平移。

这是一张显示左轴的图片:enter image description here

实际的数据集是:

y值 = [0,2,4,5,3,4,2,4,5,4,4]

左轴实际上以 0.8 为增量。

如何更改此设置?

这是我需要的:enter image description here

更新

设置后

leftAxis.grinarity = 1

这些图都在它们应该在的地方。然而,在 [0,1,2,3,4,5] 中3 被跳过并且没有显示在左轴中。什么会导致这个?

我的代码:

`class ReviewDetailVC: UIViewController, ChartViewDelegate {


@IBOutlet weak var chartView: LineChartView!

var yValues = [Double]()
var yLabels = [String]()
var months = [String]()
var xValues = [String]()
let red = UIColor(hue: 0.9639, saturation: 0.62, brightness: 0.93, alpha: 1.0)
let black = UIColor(red:0.29, green:0.29, blue:0.29, alpha:1.0)
let grey = UIColor(red:0.81, green:0.81, blue:0.81, alpha:1.0)

let avenirDemi = UIFont(name: "AvenirNext-DemiBold", size: 14)
override func viewDidLoad() {
super.viewDidLoad()

chartView.delegate = self
// Chart Ui Settings

chartView.leftAxis.axisMinimum = 0
chartView.leftAxis.axisMaximum = 5
chartView.leftAxis.labelCount = 7

chartView.chartDescription?.text = ""
chartView.xAxis.labelPosition = .bottom
chartView.legend.enabled = false
chartView.scaleYEnabled = false
chartView.scaleXEnabled = true
chartView.doubleTapToZoomEnabled = false
chartView.highlighter = nil
chartView.rightAxis.enabled = false
chartView.xAxis.drawGridLinesEnabled = false
chartView.dragEnabled = true
chartView.scaleXEnabled = false
chartView.scaleYEnabled = false
chartView.zoom(scaleX: 4, scaleY: 1, x: 0, y: CGFloat(AxisDependency.left.rawValue))
chartView.xAxis.labelFont = avenirDemi!
chartView.xAxis.labelTextColor = grey
chartView.leftAxis.labelFont = avenirDemi!
chartView.leftAxis.labelTextColor = black
chartView.xAxis.axisLineWidth = 0
chartView.leftAxis.axisLineWidth = 0
chartView.leftAxis.granularity = 1
chartView.xAxis.avoidFirstLastClippingEnabled = true
chartView.xAxis.granularityEnabled = true
chartView.xAxis.granularity = 1
chartView.xAxis.axisMinimum = 0.0
chartView.leftAxis.gridColor = grey
chartView.leftAxis.gridLineDashLengths = [4]
chartView.leftAxis.gridLineWidth = 1.5
chartView.xAxis.centerAxisLabelsEnabled = true
chartView.noDataText = "This person has not reviewed your business."

xValues = ["MAR 10"," MAR 15", "APR 7", "APR 8", "APR 15", "APR 30", "MAY 14", "MAY 21","MAY 31", "MAY 31"]
yLabels = ["0","1","2","3","4","5"]
yValues = [0,2,4,5,3,4,2,4,5,4,4]

let Xformatter = CustomLabelsAxisValueFormatter()
Xformatter.labels = xValues
let Yformatter = CustomYAxisLabelValueFormatter()
Yformatter.Ylabels = yLabels

chartView.xAxis.valueFormatter = Xformatter
chartView.leftAxis.valueFormatter = Yformatter



chartView.animate(yAxisDuration: 1)

setChart(dataPoints: xValues, values: yValues)


}



func setChart(dataPoints: [String], values: [Double]) {
chartView.noDataText = "You need to provide data for the chart."

var dataEntries: [ChartDataEntry] = []

for i in 0..<dataPoints.count {
let dataEntry = ChartDataEntry(x: Double(i)+0.5, y:
values[i])
dataEntries.append(dataEntry)
}

let chartDataSet = LineChartDataSet(values: dataEntries, label: "")
let chartData = LineChartData(dataSets: [chartDataSet])

chartDataSet.drawValuesEnabled = false
chartDataSet.colors = [red]
chartDataSet.drawCirclesEnabled = true
chartDataSet.circleRadius = 16
chartDataSet.circleColors = [red]
chartDataSet.circleHoleRadius = 12
chartDataSet.circleHoleColor = UIColor.white
chartDataSet.lineWidth = 4


chartView.data = chartData

}





@IBAction func backBtnPressed(_ sender: Any) {
self.presentingViewController?.dismiss(animated: true,
completion: nil)
}

}

class CustomLabelsAxisValueFormatter : NSObject, IAxisValueFormatter
{

var labels: [String] = []

func stringForValue(_ value: Double, axis: AxisBase?) -> String {
let count = self.labels.count

guard let axis = axis, count > 0 else {

return ""
}

let factor = axis.axisMaximum / Double(count)

let index = Int((value / factor).rounded())

if index >= 0 && index < count {

return self.labels[index]
}

return ""
}


}

class CustomYAxisLabelValueFormatter : NSObject, IAxisValueFormatter {


var Ylabels: [String] = []

func stringForValue(_ value: Double, axis: AxisBase?) -> String {
let count = self.Ylabels.count

guard let axis = axis, count > 0 else {

return ""
}

let factor = axis.axisMaximum / Double(count)

let index = Int((value / factor).rounded())

if index >= 0 && index < count {

return self.Ylabels[index]
}

return ""
}


}`

最佳答案

当我运行你的代码时,这就是我得到的:

enter image description here

所以我无法重现您的问题,我唯一更改的是取消注释这三行,因为我没有 CustomYAxisLabelValueFormatter 的代码。因此,如果您取消注释这些行,它应该可以工作。

    //let Yformatter = CustomYAxisLabelValueFormatter()
//Yformatter.Ylabels = yLabels
//chartView.leftAxis.valueFormatter = Yformatter

关于IOS 图表 Y 轴未正确对齐 - 图表 Cocoa Pod,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44748972/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com