OC调用Charts绘制图表--CombinedChartView

折线与单系列柱状图混合图表绘制数据处理赋值

 NSMutableArray *lineVals = [NSMutableArray array];
 double rightSetMin = 0;
 double rightSetMax = 0;
 NSArray *annGrowRate = @[@"2.24", @"16.79", @"14.54", @"-2.25", @"<null>"];
    
    for (int i = 0; i < annGrowRate.count; i++)
    {
        NSString *valStr = [NSString stringWithFormat:@"%@", annGrowRate[i]];

        double val = [valStr doubleValue];
        
        rightSetMax = MAX(val, rightSetMax);
        rightSetMin = MIN(val, rightSetMin);
        
        ChartDataEntry *entry = [[ChartDataEntry alloc] initWithX:i  y:val];
        [lineVals addObject:entry];
    }
    
    LineChartDataSet *lineSet = [[LineChartDataSet alloc] initWithValues:lineVals label:@"折线图"];
    lineSet.lineWidth = 3.0f;
    lineSet.drawValuesEnabled = YES;
    lineSet.valueColors = @[RGB(92, 178, 240)];
    [lineSet setColor:RGB(92, 178, 240)];
    lineSet.drawSteppedEnabled = NO;
    lineSet.drawCirclesEnabled = NO;
    lineSet.circleRadius = 3.0f;
    lineSet.drawCircleHoleEnabled = YES;
    lineSet.circleHoleRadius = 1.0f;
    lineSet.circleHoleColor = RGB(92, 178, 240);
    lineSet.highlightEnabled = NO;
    lineSet.valueFont = [UIFont systemFontOfSize:12];
    lineSet.axisDependency = AxisDependencyRight;
    LineChartData *lineData = [[LineChartData alloc] initWithDataSet:lineSet];
    //    柱状
    double leftSetMin = 0;
    double leftSetMax = 0;
    NSMutableArray *yVals = [[NSMutableArray alloc] init];
    NSArray *annBloodCol = @[@"233303.8", @"272471.46", @"312079.13", @"305052.68", @"281939.85", @""];
    
    for (int i = 0; i < annBloodCol.count ; i++)
    {
        NSString *valStr = [NSString stringWithFormat:@"%@", annBloodCol[i]];
        double val = [valStr doubleValue];
        leftSetMax = MAX(val, leftSetMax);
        leftSetMin = MIN(val, leftSetMin);
        [yVals addObject:[[BarChartDataEntry alloc] initWithX:i   y:val]];
    }
    
    BarChartDataSet *barSet =  [[BarChartDataSet alloc] initWithValues:yVals label:@"柱状图"];
    [barSet setColor:RGB(242, 152, 80)];
    barSet.highlightEnabled = NO;
    BarChartData *barData = [[BarChartData alloc] initWithDataSet:barSet];
    [barData setValueFont:[UIFont systemFontOfSize:10.f]];
    barData.barWidth = 0.5f;
    CombinedChartData *combineData = [[CombinedChartData alloc] init];

    double leftDiff = leftSetMax - leftSetMin;
    
    if (leftSetMax == 0 && leftSetMin == 0) {
        leftSetMax = 100.0;
        leftSetMin = -10.0;
    } else {
        leftSetMax = (leftSetMax + leftDiff * 0.2);
        leftSetMin = (leftSetMin - leftDiff * 0.1);
    }
    self.comChartView.leftAxis.axisMaximum = leftSetMax;
    self.comChartView.leftAxis.axisMinimum = 0;
    
    double rightDiff = rightSetMax - rightSetMin;
    if (rightSetMax == 0 && rightSetMin == 0) {
        rightSetMax = 100.0;
        rightSetMin = -10.0;
    } else {
        rightSetMax = (rightSetMax + rightDiff * 0.2);
        rightSetMin = (rightSetMin - rightDiff * 0.1);
    }
    self.comChartView.rightAxis.axisMaximum = rightSetMax;
    self.comChartView.rightAxis.axisMinimum = rightSetMin;
    _comChartView.data = nil;
    combineData.lineData = lineData;
    combineData.barData = barData;
    if (combineData.barData || combineData.lineData) {
        _comChartView.data = combineData;
        _comChartView.xAxis.axisMinimum = combineData.xMin - 0.8;
        _comChartView.xAxis.axisMaximum = 4.8;
    }
    [self.comChartView animateWithXAxisDuration:0.25f];

效果图如下:


混合图表绘制.png

混合图表绘制套路基本和折线、柱状图绘制相同,主要有俩点,在初始化的时候设置混合图表的数据类型,这里有先后顺序的,在combinedData数据赋值时候可以不按顺序,数据类型初始化的时候可以试一下,类型顺序不同,或许就被遮盖了,主要代码:

 comChartView.drawOrder = @[ @(CombinedChartDrawOrderBar), @(CombinedChartDrawOrderLine)];

combinedData赋值的时候,需要折线数据就按照LineChartData进行初始化,需要柱状图就按照BarChartData进行处理,最后把处理好的数据赋值给combinedData

 combineData.lineData = lineData; 
 combineData.barData = barData;

其他的注意点基本也都说过了,目前只研究了Charts的折线图,柱状图、折线与柱状图混合图表,相信其他的类型的套路也是一样的,有问题可以一起讨论交流,代码写的有些粗糙别见怪,以后再优化代码和文字样式,希望对大家有帮助~~😝

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,060评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,092评论 4 62
  • 之前一直都说要写关于绘制折线和柱状图的相关文章,之前在忙新的项目,这几天不忙,也是之前那篇文章有小伙伴问我折线与柱...
    咖啡bu加糖阅读 11,385评论 59 27
  • 彭子昊与袁老爷随口客套了几句,便走出府去。袁老爷战战兢兢一直送到长街口,心里千百个不愿但又不得不说出那句常来。待他...
    长楼阅读 589评论 0 0
  • 两腿之间 藏着狐仙 我有如意金箍棒 也被勒上了金箍圈 一个跟头就十万八千 一眨眼睛能七十二变 我说 行道替天 一场...
    段童阅读 572评论 0 1