Swift 功能實(shí)現(xiàn)之圖表Charts

前言

??最近在項(xiàng)目中需要添加圖表趴荸,柱狀圖和折線圖儒溉,研究了一下,今天就給大家分享一個(gè)功能非常全发钝,非常好用的圖表制作的三方框架Charts,它是一個(gè)用swift語(yǔ)言編寫(xiě)的swift三方框架顿涣,現(xiàn)在最新的版本應(yīng)該是3.0.5,大家可以去git 上去下載源碼來(lái)研究它的寫(xiě)法酝豪。 Charts涛碑。它支持多種圖表制作,這里我就選柱狀圖和折線圖來(lái)進(jìn)行介紹孵淘。

  • 下面說(shuō)一下在研究Charts時(shí)蒲障,遇到的一個(gè)小困難,我需要在圖表的X軸上顯示自定義的字符串瘫证,上網(wǎng)查閱很少有符合我的需求的介紹揉阎,就算有也是比較老的版本,照著寫(xiě)上寫(xiě)不好使背捌,最后還是下載了最新版本的源碼毙籽,通過(guò)源碼解決了這個(gè)問(wèn)題。所以如果大家要研究一個(gè)新接觸的三方框架毡庆,如果是開(kāi)源的話坑赡,第一選擇還是去下載源碼烙如,這樣會(huì)很節(jié)省時(shí)間。

柱狀圖

?? Charts的功能十分強(qiáng)大毅否,這里只是介紹它的簡(jiǎn)單使用亚铁,下面是基礎(chǔ)功能和屬性的使用介紹。

  • 添加Charts
    // 柱狀圖
    let barChartView: BarChartView = {
        $0.noDataText = "暫無(wú)統(tǒng)計(jì)數(shù)據(jù)" //無(wú)數(shù)據(jù)的時(shí)候顯示
        $0.chartDescription?.enabled = false //是否顯示描述
        $0.scaleXEnabled = false
        $0.scaleYEnabled = false

        
        $0.leftAxis.drawGridLinesEnabled = false //左側(cè)y軸設(shè)置螟加,不畫(huà)線
        $0.rightAxis.drawGridLinesEnabled = false //右側(cè)y軸設(shè)置刀闷,不畫(huà)線
        $0.rightAxis.drawAxisLineEnabled = false
        $0.rightAxis.enabled = false
        $0.legend.enabled = true
        
        return $0
    }(BarChartView())
  • x軸,y軸數(shù)值
    let xStr = ["體力", "智力", "情緒", "綜合 "] //x軸類別項(xiàng)
    let values = [98.0, 70.3, 40.1, 18.2] //x軸對(duì)應(yīng)的y軸數(shù)據(jù)
  • 配置柱狀圖仰迁,設(shè)置數(shù)據(jù)
 //配置柱狀圖
    func setBarChartViewData(_ dataPoints: [String], _ values: [Double]) {
        //x軸樣式
        let xAxis = barChartView.xAxis
        xAxis.labelPosition = .bottom //x軸的位置
        xAxis.labelFont = .systemFont(ofSize: 10)
        xAxis.drawGridLinesEnabled = false
        xAxis.granularity = 1.0
        xAxis.valueFormatter = self
        let xFormatter = IndexAxisValueFormatter()
        xFormatter.values = dataPoints

        var dataEntris: [BarChartDataEntry] = []
        for (idx, _) in dataPoints.enumerated() {
            let dataEntry = BarChartDataEntry(x: Double(idx), y: values[idx])
            dataEntris.append(dataEntry)
        }
        let chartDataSet = BarChartDataSet(values: dataEntris, label: "")
        let color = UIColor.red
        chartDataSet.colors = [color, color, color, color, color]
        let chartData = BarChartData(dataSet: chartDataSet)

        self.barChartView.data = chartData
        self.barChartView.animate(yAxisDuration: 0.4)
    }
  • 注意:這里x軸需要顯示為自定義的字符串甸昏,這里就需要去簽訂一個(gè)樣式代理,IAxisValueFormatter徐许,實(shí)現(xiàn)指定方法施蜜,折線圖也同樣如此。
//注意:這里是簽訂一個(gè)類似于x軸樣式的代理雌隅,顯示需要的自定義字符串
//在擴(kuò)展里實(shí)現(xiàn)
extension ViewController: IAxisValueFormatter {
    func stringForValue(_ value: Double, axis: AxisBase?) -> String {
        return xStr[Int(value) % xStr.count]
    }
}
  • 在VC上添加chart翻默。
    //添加柱狀圖
    func addBarChartView() {
        barChartView.frame = CGRect(x: 0, y: 50, width: 200, height: 200)
        barChartView.center.x = self.view.center.x
        self.view.addSubview(barChartView)
        setBarChartViewData(xStr, values)
    }

折線圖

??折線圖與柱狀圖基本上差不多。

  • 添加Charts
 //折線圖
    let lineChartView: LineChartView = {
        $0.noDataText = "暫無(wú)統(tǒng)計(jì)數(shù)據(jù)" //無(wú)數(shù)據(jù)的時(shí)候顯示
        $0.chartDescription?.enabled = false //是否顯示描述
        $0.scaleXEnabled = false
        $0.scaleYEnabled = false
        
        $0.leftAxis.drawGridLinesEnabled = false //左側(cè)y軸設(shè)置恰起,不畫(huà)線
        $0.rightAxis.drawGridLinesEnabled = false //右側(cè)y軸設(shè)置修械,不畫(huà)線
        $0.rightAxis.drawAxisLineEnabled = false
        $0.rightAxis.enabled = false
        $0.legend.enabled = true
        
        return $0

    }(LineChartView())
  • 配置折線圖,設(shè)置數(shù)據(jù)
    //配置折線圖
    func setLineChartViewData(_ dataPoints: [String], _ values: [Double]) {
        
        let xAxis = lineChartView.xAxis
        xAxis.labelPosition = .bottom //x軸的位置
        xAxis.labelFont = .systemFont(ofSize: 10)
        xAxis.drawGridLinesEnabled = false
        xAxis.granularity = 1.0
        xAxis.valueFormatter = self
        
        var dataEntris: [ChartDataEntry] = []
        for (idx, _) in dataPoints.enumerated() {
            let dataEntry = ChartDataEntry(x: Double(idx), y: values[idx])
            dataEntris.append(dataEntry)
        }
        let lineChartDataSet = LineChartDataSet(values: dataEntris, label: "")
        //外圈
        lineChartDataSet.setCircleColor(UIColor.yellow)
        //內(nèi)圈
        lineChartDataSet.circleHoleColor = UIColor.red
        //線條顯示樣式
        lineChartDataSet.colors = [UIColor.gray]
        
        let lineChartData = LineChartData(dataSet: lineChartDataSet)
        lineChartView.data = lineChartData
        
        //設(shè)置x軸樣式
        let xFormatter = IndexAxisValueFormatter()
        xFormatter.values = dataPoints
        
        self.lineChartView.animate(xAxisDuration: 0.4)
    }
  • VC上添加chart
//添加折線圖
    func addLineChartView() {
        lineChartView.frame = CGRect(x: 0, y: 300, width: 200, height: 200)
        lineChartView.center.x = self.view.center.x
        self.view.addSubview(lineChartView)
        setLineChartViewData(xStr, values)
    }

效果圖

效果圖

最后

附上demo鏈接检盼,https://github.com/Sufviay/ChartsTest

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末肯污,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子吨枉,更是在濱河造成了極大的恐慌蹦渣,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件貌亭,死亡現(xiàn)場(chǎng)離奇詭異柬唯,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)圃庭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門锄奢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人剧腻,你說(shuō)我怎么就攤上這事拘央。” “怎么了恕酸?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵堪滨,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蕊温,道長(zhǎng)袱箱,這世上最難降的妖魔是什么遏乔? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮发笔,結(jié)果婚禮上盟萨,老公的妹妹穿的比我還像新娘。我一直安慰自己了讨,他們只是感情好捻激,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著前计,像睡著了一般胞谭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上男杈,一...
    開(kāi)封第一講書(shū)人閱讀 51,692評(píng)論 1 305
  • 那天丈屹,我揣著相機(jī)與錄音,去河邊找鬼伶棒。 笑死旺垒,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的肤无。 我是一名探鬼主播先蒋,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼宛渐!你這毒婦竟也來(lái)了竞漾?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤皇忿,失蹤者是張志新(化名)和其女友劉穎畴蹭,沒(méi)想到半個(gè)月后坦仍,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體鳍烁,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年繁扎,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了幔荒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡梳玫,死狀恐怖爹梁,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情提澎,我是刑警寧澤姚垃,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站盼忌,受9級(jí)特大地震影響积糯,放射性物質(zhì)發(fā)生泄漏掂墓。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一看成、第九天 我趴在偏房一處隱蔽的房頂上張望君编。 院中可真熱鬧,春花似錦川慌、人聲如沸吃嘿。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)兑燥。三九已至,卻和暖如春琴拧,著一層夾襖步出監(jiān)牢的瞬間贪嫂,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工艾蓝, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留力崇,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓赢织,卻偏偏與公主長(zhǎng)得像亮靴,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子于置,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 太長(zhǎng)了茧吊,還是轉(zhuǎn)載吧...今天在看博客的時(shí)候,無(wú)意中發(fā)現(xiàn)了@Trinea在GitHub上的一個(gè)項(xiàng)目Android開(kāi)源...
    龐哈哈哈12138閱讀 20,197評(píng)論 3 283
  • 我的母親是個(gè)堅(jiān)強(qiáng)的女人八毯,從前我不懂搓侄,后來(lái)明白在鬼門關(guān)繞了好幾趟又原路返回的她現(xiàn)在能明白生活的美好是多么幸福的事情。...
    明明如是閱讀 213評(píng)論 0 1
  • 昨天在學(xué)習(xí)Maven時(shí)话速,一個(gè)作業(yè)要求使用log4j來(lái)管理日志 pom.xml的配置 要使用log4j讶踪,首先在 po...
    柚子光譜閱讀 12,889評(píng)論 2 2
  • 記得高考過(guò)后,老爸曾對(duì)我說(shuō)過(guò)泊交,大學(xué)的錄取通知是一封離別書(shū)乳讥,當(dāng)時(shí)覺(jué)得無(wú)所謂,因?yàn)榧倨谶€長(zhǎng)廓俭,學(xué)校也未知云石。如今,我真的離...
    黑貓幽默閱讀 271評(píng)論 0 0