iOS图表库Charts集成与使用

  Charts是一个很优秀的图表库,它支持Android、iOS、tvOS和macOS,这样使用起来,可以节省学习成本,可以从GitHub上了解更多信息。本文记录在iOS项目上的集成与使用。

  

    Charts目前版本是3.0.1,要求使用xcode8和swift3.0,最低支持iOS8.0,如果需要使用2.3.0版本的,需要在xcode8设置使用swift2.3版本的编译器,但是,苹果估计迟早会在后面版本移除2.3版本的支持吧,从swift发布开始就一路使用过来的同学体会应该很深,每次升级xcode,就要改一次swift代码,感觉掉进了无底深坑有木有~~~~~~所以,这里就使用3.0.1版本的吧!

  1. 新建测试项目,为了方便,使用swift语言来写,当然,也可以使用Objective-C来写,配置好桥接文件就可以了,也不难。

  2. 下载Charts项目,解压后项目文件如下:

    

   3. 添加项目"Charts.xcodeproj"到我们项目中:

    

    添加后如下:

    

   4. 添加framework支持:

    

    5. 编写测试代码:

      直接在原有ViewController类编写,直接代码写简单的view,Demo是用Objective-C写的,这里用Swift改写同样功能,代码如下:

//
//  ViewController.swift
//  TestCharts
//
//  Created by LinJK on 22/12/2016.
//  Copyright © 2016 LinJK. All rights reserved.
//

import UIKit
import Charts

class ViewController: UIViewController, ChartViewDelegate{
    
    var charView:LineChartView?
    var xAxis:XAxis?

    override func viewDidLoad() {
        super.viewDidLoad()
        //
        charView = LineChartView(frame: CGRect(x: 0, y: 50, width: 300, height: 200))
        charView!.delegate = self
        charView!.chartDescription?.enabled = false
        charView!.dragEnabled = false
        charView!.setScaleEnabled(true)
        charView!.pinchZoomEnabled = false
        charView!.drawGridBackgroundEnabled = false
        charView!.highlightPerDragEnabled = true
        charView!.backgroundColor = UIColor.white
        charView!.legend.enabled = true
        
        xAxis = charView?.xAxis
        xAxis!.labelPosition = XAxis.LabelPosition.topInside
        xAxis!.labelFont = UIFont(name: "HelveticaNeue", size: 10)!
        xAxis!.labelTextColor = UIColor(red: 255/255.0, green: 192/255.0, blue: 56/255.0, alpha: 1.0)
        xAxis!.drawAxisLineEnabled = false
        xAxis!.drawGridLinesEnabled = true
        xAxis!.centerAxisLabelsEnabled = true
        xAxis!.granularity = 3600.0
        
        charView!.rightAxis.enabled = false
        charView!.legend.form = Legend.Form.line
        
        self.view.addSubview(charView!)
        
        self.updateChartData()
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func updateChartData() {
        let count = 100.0
        let range = 30.0
        let hourSeconds:TimeInterval = 3600.0
        let now = NSDate().timeIntervalSince1970
        let from:TimeInterval = now-(count/2.0)*hourSeconds
        let to:TimeInterval = now+(count/2.0)*hourSeconds
        
        var values:[ChartDataEntry] = []
        
        var x = from
        while x < to {
            values.append(ChartDataEntry(x: x, y: Double(arc4random_uniform(UInt32(range)))+50))
            
            x += hourSeconds
        }
        
        var set1:LineChartDataSet?
        
        set1 = LineChartDataSet(values: values, label: "DataSet1")
        set1!.axisDependency = YAxis.AxisDependency.left
        set1!.valueTextColor = UIColor(red: 51/255.0, green: 181/255.0, blue: 229/255.0, alpha: 1.0)
        set1!.lineWidth = 1.5
        set1!.drawCirclesEnabled = false
        set1!.drawValuesEnabled = false
        set1!.fillAlpha = 0.26
        set1!.fillColor = UIColor(red: 51/255.0, green: 181/255.0, blue: 229/255.0, alpha: 1.0)
        set1!.highlightColor = UIColor(red: 224/255.0, green: 117/255.0, blue: 117/255.0, alpha: 1.0)
        set1!.drawCircleHoleEnabled = false
        
        var dataSets:[ChartDataSet] = []
        dataSets.append(set1!)
        
        let data:LineChartData! = LineChartData(dataSets: dataSets)
        data.setValueTextColor(UIColor.white)
        data.setValueFont(UIFont(name: "HelveticaNeue-Light", size: 9.0))
        
        charView?.data = data
        
        if charView!.data!.dataSetCount > 0 {
            set1 = charView!.data?.dataSets[0] as! LineChartDataSet?
            set1!.values = values
            charView!.data?.notifyDataChanged()
            charView!.notifyDataSetChanged()
        }
    }
    
    //MARK: ChartViewDelegate
    func chartValueSelected(_ chartView: ChartViewBase, entry: ChartDataEntry, highlight: Highlight) {
        print("chartValueSelected")
    }
    
    func chartValueNothingSelected(_ chartView: ChartViewBase) {
        print("chartValueNothingSelected")
    }
}

     使用上很简单,直接import Charts,然后新建一个view绑定到需要显示的图形类型库,并对其进行显示配置和数据填充即可。运行结果如下:

    

    其他的图形类似,这里就不重复了,大家可以测试使用一下。

 

posted @ 2016-12-23 11:06  LinJK  阅读(872)  评论(0编辑  收藏  举报