iOS使用Charts框架繪制—折線圖

首先先看一下效果:

折線圖

一送朱、 初始化折線圖對(duì)象

創(chuàng)建一個(gè)折線圖的用到的類是LineChartView.h, 代碼如下:

self.LineChartView = [[LineChartView alloc] init];
self.LineChartView.delegate = self;//設(shè)置代理
[self.view addSubview:self.LineChartView];
[self.LineChartView mas_makeConstraints:^(MASConstraintMaker *make) {
      make.size.mas_equalTo(CGSizeMake(self.view.bounds.size.width-20, 300));
      make.center.mas_equalTo(self.view);
}];
self.LineChartView.backgroundColor =  [UIColor colorWithRed:230/255.0f green:253/255.0f blue:253/255.0f alpha:1];
self.LineChartView.noDataText = @"暫無(wú)數(shù)據(jù)";

二驶沼、設(shè)置折線圖外觀樣式

1.設(shè)置交互樣式
self.LineChartView.scaleYEnabled = NO;//取消Y軸縮放
self.LineChartView.doubleTapToZoomEnabled = NO;//取消雙擊縮放
self.LineChartView.dragEnabled = YES;//啟用拖拽圖標(biāo)
self.LineChartView.dragDecelerationEnabled = YES;//拖拽后是否有慣性效果
self.LineChartView.dragDecelerationFrictionCoef = 0.9;//拖拽后慣性效果的摩擦系數(shù)(0~1),數(shù)值越小大年,慣性越不明顯
2.設(shè)置X軸樣式
ChartXAxis *xAxis = self.LineChartView.xAxis;
xAxis.axisLineWidth = 1.0/[UIScreen mainScreen].scale;//設(shè)置X軸線寬
xAxis.labelPosition = XAxisLabelPositionBottom;//X軸的顯示位置玉雾,默認(rèn)是顯示在上面的
xAxis.drawGridLinesEnabled = NO;//不繪制網(wǎng)格線
xAxis.spaceBetweenLabels = 4;//設(shè)置label間隔
xAxis.labelTextColor = [self colorWithHexString:@"#057748"];//label文字顏色
3.設(shè)置Y軸樣式
self.LineChartView.rightAxis.enabled = NO;//不繪制右邊軸
ChartYAxis *leftAxis = self.LineChartView.leftAxis;//獲取左邊Y軸
leftAxis.labelCount = 5;//Y軸label數(shù)量复旬,數(shù)值不一定,如果forceLabelsEnabled等于YES, 則強(qiáng)制繪制制定數(shù)量的label, 但是可能不平均
leftAxis.forceLabelsEnabled = NO;//不強(qiáng)制繪制指定數(shù)量的label
leftAxis.showOnlyMinMaxEnabled = NO;//是否只顯示最大值和最小值
leftAxis.axisMinValue = 0;//設(shè)置Y軸的最小值
leftAxis.startAtZeroEnabled = YES;//從0開(kāi)始繪制
leftAxis.axisMaxValue = 105;//設(shè)置Y軸的最大值
leftAxis.inverted = NO;//是否將Y軸進(jìn)行上下翻轉(zhuǎn)
leftAxis.axisLineWidth = 1.0/[UIScreen mainScreen].scale;//Y軸線寬
leftAxis.axisLineColor = [UIColor blackColor];//Y軸顏色
leftAxis.valueFormatter = [[NSNumberFormatter alloc] init];//自定義格式
leftAxis.valueFormatter.positiveSuffix = @" $";//數(shù)字后綴單位
leftAxis.labelPosition = YAxisLabelPositionOutsideChart;//label位置
leftAxis.labelTextColor = [self colorWithHexString:@"#057748"];//文字顏色
leftAxis.labelFont = [UIFont systemFontOfSize:10.0f];//文字字體
4.設(shè)置網(wǎng)格線樣式

主要是設(shè)置Y軸的網(wǎng)格線樣式, 代碼如下:

leftAxis.gridLineDashLengths = @[@3.0f, @3.0f];//設(shè)置虛線樣式的網(wǎng)格線
leftAxis.gridColor = [UIColor colorWithRed:200/255.0f green:200/255.0f blue:200/255.0f alpha:1];//網(wǎng)格線顏色
leftAxis.gridAntialiasEnabled = YES;//開(kāi)啟抗鋸齒
5.添加限制線

限制線可以添加多條, 在這里只添加一條做演示, 代碼如下:

ChartLimitLine *limitLine = [[ChartLimitLine alloc] initWithLimit:80 label:@"限制線"];
limitLine.lineWidth = 2;
limitLine.lineColor = [UIColor greenColor];
limitLine.lineDashLengths = @[@5.0f, @5.0f];//虛線樣式
limitLine.labelPosition = ChartLimitLabelPositionRightTop;//位置
limitLine.valueTextColor = [self colorWithHexString:@"#057748"];//label文字顏色
limitLine.valueFont = [UIFont systemFontOfSize:12];//label字體
[leftAxis addLimitLine:limitLine];//添加到Y(jié)軸上
leftAxis.drawLimitLinesBehindDataEnabled = YES;//設(shè)置限制線繪制在折線圖的后面
6.設(shè)置折線圖描述及圖例樣式

當(dāng)有多條折線顯示在圖表上時(shí), 通常需要一個(gè)'圖例'來(lái)說(shuō)明每一條折線的名稱或者代表的含義, 這時(shí)候就要進(jìn)行圖例的設(shè)置, 主要代碼如下:

[self.LineChartView setDescriptionText:@"折線圖"];//折線圖描述
[self.LineChartView setDescriptionTextColor:[UIColor darkGrayColor]];
self.LineChartView.legend.form = ChartLegendFormLine;//圖例的樣式
self.LineChartView.legend.formSize = 30;//圖例中線條的長(zhǎng)度
self.LineChartView.legend.textColor = [UIColor darkGrayColor];//圖例文字顏色

除了可以用以上這些屬性來(lái)設(shè)置樣式以外, 還有其它很多屬性, 可以自行嘗試. 由于以上這些屬性較簡(jiǎn)單, 從屬性名就可以看出其含義, 而且在代碼后面也大都有注釋, 在這里就不對(duì)這些屬性作一一解釋了.

三、為折線圖提供數(shù)據(jù)

為折線圖提供數(shù)據(jù), 和柱形圖差不多, 唯一不同的是設(shè)置折線圖的折線線條樣式, 在設(shè)置線條樣式時(shí), 我們可以設(shè)置折線的類型, 有階梯類型和一般類型. 我們也可以設(shè)置折線拐點(diǎn)的樣式, 拐點(diǎn)的大小, 拐點(diǎn)是否可以是空心類型等. 此外還可以對(duì)折線圖進(jìn)行顏色填充, 以此來(lái)美化圖表. 由于樣式太多, 在這里就不多說(shuō)了, 直接看代碼:

- (LineChartData *)setData{
    
    int xVals_count = 12;//X軸上要顯示多少條數(shù)據(jù)
    double maxYVal = 100;//Y軸的最大值
    
    //X軸上面需要顯示的數(shù)據(jù)
    NSMutableArray *xVals = [[NSMutableArray alloc] init];
    for (int i = 0; i < xVals_count; i++) {
        [xVals addObject:[NSString stringWithFormat:@"%d月", i+1]];
    }
    
    //對(duì)應(yīng)Y軸上面需要顯示的數(shù)據(jù)
    NSMutableArray *yVals = [[NSMutableArray alloc] init];
    for (int i = 0; i < xVals_count; i++) {
        double mult = maxYVal + 1;
        double val = (double)(arc4random_uniform(mult));
        ChartDataEntry *entry = [[ChartDataEntry alloc] initWithValue:val xIndex:i];
        [yVals addObject:entry];
    }
    
    LineChartDataSet *set1 = nil;
    if (self.LineChartView.data.dataSetCount > 0) {
        LineChartData *data = (LineChartData *)self.LineChartView.data;
        set1 = (LineChartDataSet *)data.dataSets[0];
        set1.yVals = yVals;
        return data;
    }else{
        //創(chuàng)建LineChartDataSet對(duì)象
        set1 = [[LineChartDataSet alloc] initWithYVals:yVals label:@"lineName"];
        //設(shè)置折線的樣式
        set1.lineWidth = 1.0/[UIScreen mainScreen].scale;//折線寬度
        set1.drawValuesEnabled = YES;//是否在拐點(diǎn)處顯示數(shù)據(jù)
        set1.valueColors = @[[UIColor brownColor]];//折線拐點(diǎn)處顯示數(shù)據(jù)的顏色
        [set1 setColor:[self colorWithHexString:@"#007FFF"]];//折線顏色
        set1.drawSteppedEnabled = NO;//是否開(kāi)啟繪制階梯樣式的折線圖
        //折線拐點(diǎn)樣式
        set1.drawCirclesEnabled = NO;//是否繪制拐點(diǎn)
        set1.circleRadius = 4.0f;//拐點(diǎn)半徑
        set1.circleColors = @[[UIColor redColor], [UIColor greenColor]];//拐點(diǎn)顏色
        //拐點(diǎn)中間的空心樣式
        set1.drawCircleHoleEnabled = YES;//是否繪制中間的空心
        set1.circleHoleRadius = 2.0f;//空心的半徑
        set1.circleHoleColor = [UIColor blackColor];//空心的顏色
        //折線的顏色填充樣式
        //第一種填充樣式:單色填充
//        set1.drawFilledEnabled = YES;//是否填充顏色
//        set1.fillColor = [UIColor redColor];//填充顏色
//        set1.fillAlpha = 0.3;//填充顏色的透明度
        //第二種填充樣式:漸變填充
        set1.drawFilledEnabled = YES;//是否填充顏色
        NSArray *gradientColors = @[(id)[ChartColorTemplates colorFromString:@"#FFFFFFFF"].CGColor,
                                    (id)[ChartColorTemplates colorFromString:@"#FF007FFF"].CGColor];
        CGGradientRef gradientRef = CGGradientCreateWithColors(nil, (CFArrayRef)gradientColors, nil);
        set1.fillAlpha = 0.3f;//透明度
        set1.fill = [ChartFill fillWithLinearGradient:gradientRef angle:90.0f];//賦值填充顏色對(duì)象
        CGGradientRelease(gradientRef);//釋放gradientRef
        
        //點(diǎn)擊選中拐點(diǎn)的交互樣式
        set1.highlightEnabled = YES;//選中拐點(diǎn),是否開(kāi)啟高亮效果(顯示十字線)
        set1.highlightColor = [self colorWithHexString:@"#c83c23"];//點(diǎn)擊選中拐點(diǎn)的十字線的顏色
        set1.highlightLineWidth = 1.0/[UIScreen mainScreen].scale;//十字線寬度
        set1.highlightLineDashLengths = @[@5, @5];//十字線的虛線樣式
        
        //將 LineChartDataSet 對(duì)象放入數(shù)組中
        NSMutableArray *dataSets = [[NSMutableArray alloc] init];
        [dataSets addObject:set1];
        
        //添加第二個(gè)LineChartDataSet對(duì)象
//        LineChartDataSet *set2 = [set1 copy];
//        NSMutableArray *yVals2 = [[NSMutableArray alloc] init];
//        for (int i = 0; i < xVals_count; i++) {
//            double mult = maxYVal + 1;
//            double val = (double)(arc4random_uniform(mult));
//            ChartDataEntry *entry = [[ChartDataEntry alloc] initWithValue:val xIndex:i];
//            [yVals2 addObject:entry];
//        }
//        set2.yVals = yVals2;
//        [set2 setColor:[UIColor redColor]];
//        set2.drawFilledEnabled = YES;//是否填充顏色
//        set2.fillColor = [UIColor redColor];//填充顏色
//        set2.fillAlpha = 0.1;//填充顏色的透明度
//        [dataSets addObject:set2];
        
        //創(chuàng)建 LineChartData 對(duì)象, 此對(duì)象就是lineChartView需要最終數(shù)據(jù)對(duì)象
        LineChartData *data = [[LineChartData alloc] initWithXVals:xVals dataSets:dataSets];
        [data setValueFont:[UIFont fontWithName:@"HelveticaNeue-Light" size:8.f]];//文字字體
        [data setValueTextColor:[UIColor grayColor]];//文字顏色
        NSNumberFormatter *formatter = [[NSNumberFormatter alloc] init];
        //自定義數(shù)據(jù)顯示格式
        [formatter setNumberStyle:NSNumberFormatterDecimalStyle];
        [formatter setPositiveFormat:@"#0.0"];
        [data setValueFormatter:formatter];
        
        
        return data;
    }
    
}

代理方法和其他圖表一樣竟坛,這里就不再贅述了.
運(yùn)行結(jié)果如下:

運(yùn)行結(jié)果

為折線圖提供數(shù)據(jù)的用到的是LineChartData類創(chuàng)建的對(duì)象, 在LineChartData對(duì)象初始化時(shí), 需要提供dataSets數(shù)組(里面放的是LineChartDataSet對(duì)象), 上面的例子中dataSets數(shù)組中只有一個(gè)LineChartDataSet對(duì)象, 也就是只有一條折線, 我們也可以在dataSets數(shù)組中放入多個(gè)LineChartDataSet對(duì)象, 也就是多條曲線, 下面的結(jié)果就是添加2條折線的效果, 如下圖:

多條折線的折線圖

Demo 地址: LineChartDemo.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末担汤,一起剝皮案震驚了整個(gè)濱河市洼冻,隨后出現(xiàn)的幾起案子碘赖,更是在濱河造成了極大的恐慌,老刑警劉巖普泡,帶你破解...
    沈念sama閱讀 206,126評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件撼班,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡砰嘁,警方通過(guò)查閱死者的電腦和手機(jī)勘究,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門口糕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)磕蛇,“玉大人,你說(shuō)我怎么就攤上這事超棺『茄啵” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵氧苍,是天一觀的道長(zhǎng)霍衫。 經(jīng)常有香客問(wèn)我侯养,道長(zhǎng),這世上最難降的妖魔是什么裸弦? 我笑而不...
    開(kāi)封第一講書人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上逞泄,老公的妹妹穿的比我還像新娘。我一直安慰自己各谚,他們只是感情好到千,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著膀息,像睡著了一般。 火紅的嫁衣襯著肌膚如雪潜支。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 48,970評(píng)論 1 284
  • 那天辑奈,我揣著相機(jī)與錄音已烤,去河邊找鬼。 笑死稍计,一個(gè)胖子當(dāng)著我的面吹牛裕循,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播硅则,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼株婴,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了大审?” 一聲冷哼從身側(cè)響起座哩,我...
    開(kāi)封第一講書人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎姜骡,沒(méi)想到半個(gè)月后屿良,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,400評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡士败,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評(píng)論 2 323
  • 正文 我和宋清朗相戀三年谅将,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饥臂。...
    茶點(diǎn)故事閱讀 37,997評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡隅熙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出囚戚,到底是詐尸還是另有隱情,我是刑警寧澤匾二,帶...
    沈念sama閱讀 33,646評(píng)論 4 322
  • 正文 年R本政府宣布拳芙,位于F島的核電站,受9級(jí)特大地震影響分飞,放射性物質(zhì)發(fā)生泄漏睹限。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評(píng)論 3 307
  • 文/蒙蒙 一删窒、第九天 我趴在偏房一處隱蔽的房頂上張望顺囊。 院中可真熱鬧蕉拢,春花似錦特碳、人聲如沸晕换。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至敏释,卻和暖如春摸袁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蜂大。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工蝶怔, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人添谊。 一個(gè)月前我還...
    沈念sama閱讀 45,423評(píng)論 2 352
  • 正文 我出身青樓斩狱,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親所踊。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評(píng)論 2 345

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