ios-charts之折线图

给大家分享一个关于折线图的第三方框架 是一个关于图表的框架 在github上面拥有16.8k的星星数 是一个非常不错的框架
附上核心功能

核心功能

下面给大家介绍下折线图的使用
我使用pod集成的charts
在使用的过程中遇到不少问题,希望大家看过之后可以少走一些弯路
一:集成
在podfile中添加

pod 'Charts'
pod 'ChartsRealm'

注意他是一个swift框架所以要添加

use_frameworks!

ps:有的时候可能集成的很慢请耐心等待
集成下来以后会报很多错误,大概就是说swift版本的问题
那我们就需要设置一下版本

pod设置

然后接下来就可以去项目中使用它了
二:使用
由于它是一个swift框架所以需要创建一个桥接文件
首先创建一个swift文件,创建的时候会弹出下面的弹窗
桥接文件

点击最后一个就可以了
到此 前面的准备工作就告一段落了 接下来就进入写代码的时候了
折线图
折线图的LineChartView

//折线图
@property (nonatomic,strong) LineChartView * lineView;//折线图
@property (nonatomic,strong) UILabel * markY;
@property (nonatomic, strong) LineChartDataSet *set1;//折线
@property (nonatomic, strong) LineChartDataSet *set2;
//折线图
- (UILabel *)markY{
    if (!_markY) {
        _markY = [[UILabel alloc]initWithFrame:CGRectMake(0, 0, 35, 25)];
        _markY.font = [UIFont systemFontOfSize:15.0];
        _markY.textAlignment = NSTextAlignmentCenter;
        _markY.text =@"";
        _markY.textColor = [UIColor whiteColor];
        _markY.backgroundColor = [UIColor grayColor];
    }
    return _markY;
}

- (LineChartView *)lineView {
    if (!_lineView) {
        _lineView = [[LineChartView alloc] initWithFrame:CGRectMake(20, 40, kScreenWidth - 40, kScreenHeight - 160)];
        _lineView.delegate = self;//设置代理
        _lineView.backgroundColor =  [UIColor whiteColor];
        _lineView.noDataText = @"暂无数据";
        _lineView.chartDescription.enabled = YES;
        _lineView.scaleYEnabled = NO;//取消Y轴缩放
        _lineView.doubleTapToZoomEnabled = NO;//取消双击缩放
        
        _lineView.dragEnabled = NO;//启用拖拽图标
        _lineView.userInteractionEnabled = YES;
        _lineView.dragDecelerationEnabled = NO;//拖拽后是否有惯性效果
        
        _lineView.dragDecelerationFrictionCoef = 0.9;//拖拽后惯性效果的摩擦系数(0~1),数值越小,惯性越不明显
        //设置滑动时候标签
        ChartMarkerView *markerY = [[ChartMarkerView alloc]
                                    init];
        markerY.offset = CGPointMake(-999, -8);
        markerY.chartView = _lineView;
        _lineView.marker = markerY;
        [markerY addSubview:self.markY];
        _lineView.rightAxis.enabled = NO;//不绘制右边轴
        ChartYAxis *leftAxis = _lineView.leftAxis;//获取左边Y轴
        //        leftAxis.labelCount = 6;//Y轴label数量,数值不一定,如果forceLabelsEnabled等于YES, 则强制绘制制定数量的label, 但是可能不平均
        leftAxis.forceLabelsEnabled = NO;//不强制绘制指定数量的label
        leftAxis.axisMinValue = 0;//设置Y轴的最小值
        leftAxis.axisMaxValue = 100;//设置Y轴的最大值
        leftAxis.inverted = NO;//是否将Y轴进行上下翻转
        leftAxis.axisLineColor = [UIColor blackColor];//Y轴颜色
        leftAxis.valueFormatter = [[SymbolsValueFormatter alloc]init];
        leftAxis.labelPosition = YAxisLabelPositionOutsideChart;//label位置
        leftAxis.labelTextColor = [UIColor blackColor];//文字颜色
        leftAxis.labelFont = [UIFont systemFontOfSize:10.0f];//文字字体
        leftAxis.gridColor = [UIColor lightGrayColor];//网格线颜色
        leftAxis.gridAntialiasEnabled = NO;//开启抗锯齿
        
        ChartXAxis *xAxis = _lineView.xAxis;
        xAxis.granularityEnabled = YES;//设置重复的值不显示
        xAxis.labelPosition= XAxisLabelPositionBottom;//设置x轴数据在底部
        xAxis.gridColor = [UIColor clearColor];
        xAxis.labelTextColor = [UIColor blackColor];//文字颜色
        xAxis.axisLineColor = [UIColor grayColor];
        xAxis.labelCount = 31;
        xAxis.axisMinimum = 1;
        xAxis.axisMaximum = 31;
        _lineView.maxVisibleCount = 999;//
        //描述及图例样式
        [_lineView setDescriptionText:@""];
        _lineView.legend.enabled = NO;
        
        BalloonMarker *marker = [[BalloonMarker alloc]
                                 initWithColor: [UIColor colorWithWhite:180/255. alpha:1.0]
                                 font: [UIFont systemFontOfSize:12.0]
                                 textColor: UIColor.whiteColor
                                 insets: UIEdgeInsetsMake(8.0, 8.0, 20.0, 8.0)];
        marker.chartView = _lineView;
        marker.minimumSize = CGSizeMake(80.f, 40.f);
        _lineView.marker = marker;
//        _lineView.legend.form = ChartLegendFormLine;
        
        [_lineView animateWithXAxisDuration:1.0f];
        
    }
    return _lineView;
}

在对应的地方添加上即可

[self.view addSubview:self.lineView];

添加完后我们需要输入数据

- (LineChartData *)setData{
    
    //对应Y轴上面需要显示的数据
    NSMutableArray *yVals = [[NSMutableArray alloc] init];
    
    for (int i = 0; i < xVals_count; i++) {
        int a = arc4random() % 100;
        ChartDataEntry *entry = [[ChartDataEntry alloc] initWithX:i y:a];
        [yVals addObject:entry];
    }
    
    _set1 = nil;
    if (_lineView.data.dataSetCount > 0) {
        LineChartData *data = (LineChartData *)_lineView.data;
        _set1 = (LineChartDataSet *)data.dataSets[0];
        _set1.values = yVals;
        _set1.valueFormatter = [[SetValueFormatter alloc]initWithArr:yVals];
        return data;
    }else{
        //创建LineChartDataSet对象
        _set1 = [[LineChartDataSet alloc]initWithValues:yVals label:nil];
        //设置折线的样式
        _set1.lineWidth = 3.0/[UIScreen mainScreen].scale;//折线宽度
        _set1.drawValuesEnabled = NO;//是否在拐点处显示数据
        _set1.valueFormatter = [[SetValueFormatter alloc]initWithArr:yVals];
        
        _set1.valueColors = @[[UIColor colorWithHexString:@"#E88C39" alpha:1.0]];//折线拐点处显示数据的颜色
        _set1.circleRadius = 3;
        [_set1 setDrawCirclesEnabled:YES];
        [_set1 setCircleColor:[UIColor colorWithHexString:@"#E88C39" alpha:1.0]];
        [_set1 setColor:[UIColor colorWithHexString:@"#E88C39" alpha:1.0]];//折线颜色
        _set1.highlightColor = [UIColor colorWithHexString:@"#E88C39" alpha:1.0];
        _set1.drawSteppedEnabled = NO;//是否开启绘制阶梯样式的折线图
        //折线拐点样式
        _set1.drawCirclesEnabled = YES;//是否绘制拐点
        _set1.drawFilledEnabled = NO;//是否填充颜色
        
        //将 LineChartDataSet 对象放入数组中
        _dataSets = [[NSMutableArray alloc] init];
        
        [_dataSets addObject:_set1];
        
        
        //添加第二个LineChartDataSet对象
        
        NSMutableArray *yVals2 = [[NSMutableArray alloc] init];
        for (int i = 0; i <  xVals_count; i++) {
            int a = arc4random() % 80;
            ChartDataEntry *entry = [[ChartDataEntry alloc] initWithX:i y:a];
            [yVals2 addObject:entry];
        }
        _set2 = [_set1 copy];
        
        _set2.values = yVals2;
        _set2.drawValuesEnabled = NO;
        [_set2 setColor:[UIColor colorWithRed:0/255.0 green:199/255.0 blue:181/255.0 alpha:1/1.0]];
        [_set2 setCircleColor:[UIColor colorWithRed:0/255.0 green:199/255.0 blue:181/255.0 alpha:1/1.0]];

        _set2.highlightColor = [UIColor colorWithRed:0/255.0 green:199/255.0 blue:181/255.0 alpha:1/1.0];
        [_dataSets addObject:_set2];
        
        
        
        //创建 LineChartData 对象, 此对象就是lineChartView需要最终数据对象
        LineChartData *data = [[LineChartData alloc]initWithDataSets:_dataSets];
        [data setValueFont:[UIFont fontWithName:@"HelveticaNeue-Light" size:11.f]];//文字字体
        [data setValueTextColor:[UIColor blackColor]];//文字颜色
        
        
        return data;
    }
    
}

在添加完成后调用即可

self.lineView.data = [self setData];

不要忘记代理方法

<ChartViewDelegate>
- (void)chartValueSelected:(ChartViewBase * _Nonnull)chartView entry:(ChartDataEntry * _Nonnull)entry highlight:(ChartHighlight * _Nonnull)highlight {
    
    _markY.text = [NSString stringWithFormat:@"%ld%%",(NSInteger)entry.y];
    //将点击的数据滑动到中间
    [_lineView centerViewToAnimatedWithXValue:entry.x yValue:entry.y axis:[_lineView.data getDataSetByIndex:highlight.dataSetIndex].axisDependency duration:1.0];
    
    
}
- (void)chartValueNothingSelected:(ChartViewBase * _Nonnull)chartView {
    
    
}

如果你想添加一条折线的话

//添加折线
- (void)click:(UIColor *)color Button:(BSWColorButton *) btn {
    
    NSMutableArray *yVals2 = [[NSMutableArray alloc] init];
    for (int i = 0; i <  xVals_count; i++) {
        int a = arc4random() % 80;
        ChartDataEntry *entry = [[ChartDataEntry alloc] initWithX:i y:a];
        [yVals2 addObject:entry];
    }
    LineChartDataSet *set2 = [_set1 copy];
    
    set2.values = yVals2;
    set2.drawValuesEnabled = NO;
    set2.highlightColor = color;
    [set2 setColor:color];
    [set2 setCircleColor:color];
    [_dataSets addObject:set2];
    //创建 LineChartData 对象, 此对象就是lineChartView需要最终数据对象
    LineChartData *data = [[LineChartData alloc]initWithDataSets:_dataSets];
    [data setValueFont:[UIFont fontWithName:@"HelveticaNeue-Light" size:11.f]];//文字字体
    [data setValueTextColor:[UIColor blackColor]];//文字颜色
    self.lineView.data = data;
}

移除一个折线

- (void)removeDataSet:(BSWColorButton *)sender {
    [_dataSets removeObject:sender.set];
    //创建 LineChartData 对象, 此对象就是lineChartView需要最终数据对象
    LineChartData *data = [[LineChartData alloc]initWithDataSets:_dataSets];
    [data setValueFont:[UIFont fontWithName:@"HelveticaNeue-Light" size:11.f]];//文字字体
    [data setValueTextColor:[UIColor blackColor]];//文字颜色
    self.lineView.data = data;
}

效果图


效果图

附上传送门:https://github.com/danielgindi/Charts

希望你们少走弯路!

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

推荐阅读更多精彩内容