当前位置: > > > Swift - 第三方图表库Charts使用详解19(烛形图)

Swift - 第三方图表库Charts使用详解19(烛形图)

1,基本用法

(1)烛形图又称为 K 线图,下面是一个简单的使用样例。默认情况下:
  • 当开盘价高于收盘价时,使用实心矩形。
  • 当开盘价低于收盘价时,使用空心矩形。
import UIKit
import Charts

class ViewController: UIViewController {
    
    //烛形图
    var chartView: CandleStickChartView!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        //创建烛形图组件对象
        chartView = CandleStickChartView()
        chartView.frame = CGRect(x: 20, y: 80, width: self.view.bounds.width - 40,
                                 height: 260)
        self.view.addSubview(chartView)
        
        //第一组烛形图的10条随机数据
        let dataEntries1 = (0..<10).map { (i) -> CandleChartDataEntry in
            let val = Double(arc4random_uniform(40) + 10)
            let high = Double(arc4random_uniform(9) + 8)
            let low = Double(arc4random_uniform(9) + 8)
            let open = Double(arc4random_uniform(6) + 1)
            let close = Double(arc4random_uniform(6) + 1)
            let even = arc4random_uniform(2) % 2 == 0 //true表示开盘价高于收盘价
            return CandleChartDataEntry(x: Double(i),
                                        shadowH: val + high,
                                        shadowL: val - low,
                                        open: even ? val + open : val - open,
                                        close: even ? val - close : val + close)
        }
        let chartDataSet1 = CandleChartDataSet(values: dataEntries1, label: "图例1")
        
        //目前烛形图包括1组数据
        let chartData = CandleChartData(dataSets: [chartDataSet1])
        
        //设置烛形图数据
        chartView.data = chartData
    }
}

(2)当然我们也可以设置在何种情况下使用填充矩形,何种情况下使用空心矩形。使用下面设置后,运行结果同默认的刚好相反。
chartDataSet1.decreasingFilled = false //开盘高于收盘则使用空心矩形
chartDataSet1.increasingFilled = true //开盘低于收盘则使用实心矩形

2,修改线条宽度

chartDataSet1.shadowWidth = 4

3,修改颜色

(1)下面将所有条目的颜色统一设置为橙色。
chartDataSet1.setColor(.orange)

(2)下面将上升方块(开盘低于收盘)显示成红色,下降方块(开盘高于收盘)显示为绿色,竖线统一设置为灰色。
chartDataSet1.increasingColor = .red
chartDataSet1.decreasingColor = .green
chartDataSet1.shadowColor = .darkGray

(3)当然也可以让竖线的颜色与方框颜色一样。
chartDataSet1.increasingColor = .red
chartDataSet1.decreasingColor = .green
chartDataSet1.shadowColorSameAsCandle = true

4,不显示方块

chartDataSet1.showCandleBar = false

5,带图标的烛形图

下面样例如果当天涨幅如果超过 9 的话显示个星星图标。
//第一组烛形图的10条随机数据
let dataEntries1 = (0..<10).map { (i) -> CandleChartDataEntry in
    let val = Double(arc4random_uniform(40) + 10)
    let high = Double(arc4random_uniform(9) + 8)
    let low = Double(arc4random_uniform(9) + 8)
    let open = Double(arc4random_uniform(6) + 1)
    let close = Double(arc4random_uniform(6) + 1)
    let even = arc4random_uniform(2) % 2 == 0 //true表示开盘价高于收盘价
    //当天涨幅超过9的显示一个星星图标
    if(!even && (open + close) > 9 ){
        return CandleChartDataEntry(x: Double(i),
                                    shadowH: val + high,
                                    shadowL: val - low,
                                    open: even ? val + open : val - open,
                                    close: even ? val - close : val + close,
                                    icon: UIImage(named: "icon")!)
    }else{
        return CandleChartDataEntry(x: Double(i),
                                    shadowH: val + high,
                                    shadowL: val - low,
                                    open: even ? val + open : val - open,
                                    close: even ? val - close : val + close)
    }

}
let chartDataSet1 = CandleChartDataSet(values: dataEntries1, label: "图例1")
评论0