Charts使用的经验总结

最近刚刚完成了一个关于基金的app,这里把最近的所得汇总一下,主要是一些平时工作没遇到的bug以及一些关于基金用的三方库的使用。

三方库Charts的导入

首先吧charts添加到你的项目下,并指定它的版本为3.2.0 【对应swift的4.2版本】

charts.png

然后在对应的文件夹下pod install 成功以后打开target,开始配置

1537329139944.jpg

而后新建一个swift文件,并生成一个桥接文件,在桥接文件中添加Charts即可

1537336207776.jpg
1537336294478.jpg

线性表格的绘制

charts中的表格有许多种,这里主要拿线表LineChartView来举个🌰

首先需要准备X轴和Y轴的两个formatter 一般X轴是日期

DateValueFormatter.h

#import <Foundation/Foundation.h>
@import Charts;
@interface DateValueFormatter : NSObject<IChartAxisValueFormatter>
-(id)initWithArr:(NSArray *)arr;
@end

DateValueFormatter.m

#import "DateValueFormatter.h"

@interface DateValueFormatter()
{
    NSArray * _arr;
}
@end
@implementation DateValueFormatter
-(id)initWithArr:(NSArray *)arr{
    self = [super init];
    if (self)
    {
        _arr = arr;
        
    }
    return self;
}
- (NSString *)stringForValue:(double)value axis:(ChartAxisBase *)axis
{
    return _arr[(NSInteger)value];
}


@end

SymbolsValueFormatter.h

#import <Foundation/Foundation.h>
@import Charts;
@interface SymbolsValueFormatter : NSObject<IChartAxisValueFormatter>

@end

SymbolsValueFormatter.m

#import "SymbolsValueFormatter.h"


@interface SymbolsValueFormatter()

@end

@implementation SymbolsValueFormatter

-(id)init{
    if (self = [super init]) {
        
    }
    return self;
}
//返回y轴的数据
- (NSString *)stringForValue:(double)value axis:(ChartAxisBase *)axis
{
    
    return [NSString stringWithFormat:@"%.2f",(float)value];
}


@end

然后是关键的图标绘制VC

ViewController.m


#import "ViewController.h"
#import "SymbolsValueFormatter.h"
#import "DateValueFormatter.h"

@import Charts;

@interface ViewController ()<ChartViewDelegate>

@property (nonatomic, strong) LineChartView *lineChartView;
@property (nonatomic, strong) NSArray *valueArray;

@property (nonatomic, strong) UILabel *showLabel;
@property (nonatomic, strong) NSMutableArray *turnovers;
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    NSMutableArray *mArray = [NSMutableArray new];
    for (int i = 1; i < 30; i ++) {
        NSString *date = [NSString stringWithFormat:@"08-%d",i];
        NSDictionary *value = @{@"xLineValue":date,@"yValue1":@(i+1).stringValue,@"yValue2":@(i+6).stringValue};
        [mArray addObject:value];
    }
    _valueArray = mArray.copy;
    
    self.lineChartView = [[LineChartView alloc] initWithFrame:CGRectMake(0, 0, 300, 400)];
    self.lineChartView.backgroundColor = [UIColor blueColor];
    [self.view addSubview:self.lineChartView];
    
    self.lineChartView.doubleTapToZoomEnabled = NO;//禁止双击缩放 有需要可以设置为YES
    self.lineChartView.gridBackgroundColor = [UIColor orangeColor];//表框以及表内线条的颜色以及隐藏设置 根据自己需要调整
    self.lineChartView.borderColor = [UIColor redColor];
    self.lineChartView.chartDescription.enabled = false;
    self.lineChartView.noDataText = @"暂无数据";
    self.lineChartView.dragEnabled = NO;
    [self.lineChartView setScaleEnabled:NO];
    self.lineChartView.pinchZoomEnabled = NO;
    self.lineChartView.highlightPerDragEnabled = true;
    self.lineChartView.highlightPerTapEnabled = true;
    self.lineChartView.backgroundColor = [UIColor whiteColor];
    self.lineChartView.legend.enabled = NO;
    self.lineChartView.delegate = self;
    //设置动画时间
    [self.lineChartView animateWithXAxisDuration:1];
    
    ChartXAxis *xAxis = self.lineChartView.xAxis;
    xAxis.labelPosition = XAxisLabelPositionBottom;
    xAxis.axisLineColor = [UIColor clearColor];
    xAxis.labelFont = [UIFont systemFontOfSize:11];
    xAxis.labelTextColor = [UIColor blackColor];
    xAxis.drawGridLinesEnabled = false;
    xAxis.granularity = 86400;
    [xAxis setLabelCount:3 force:true];
    xAxis.avoidFirstLastClippingEnabled = true;
    
    ChartYAxis *leftAxis = self.lineChartView.leftAxis;
    leftAxis.drawGridLinesEnabled = NO;
    leftAxis.labelFont = [UIFont systemFontOfSize:11];
    leftAxis.labelTextColor = [UIColor grayColor];
    leftAxis.valueFormatter = [[SymbolsValueFormatter alloc]init];
    leftAxis.axisLineColor = [UIColor clearColor];
    
    self.lineChartView.rightAxis.enabled = false;
    self.lineChartView.legend.form = 5;
    
    [self loadData];
    
    self.showLabel = [[UILabel alloc]initWithFrame:CGRectMake(0, 450, 300, 20)];
    [self.view addSubview:self.showLabel];
}

- (void)loadData{
    NSMutableArray *line1Array = [NSMutableArray new];
    NSMutableArray *line2Array = [NSMutableArray new];
    
    //用于存放多个折线数据的数组
    NSMutableArray *sets = [NSMutableArray array];
    
    //turnovers是用于存放模型的数组
    self.turnovers = [NSMutableArray array];
    //横轴数据
    NSMutableArray *xValues = [NSMutableArray array];
    //纵轴数据
    NSMutableArray *yValues1 = [NSMutableArray array];
    NSMutableArray *yValues2 = [NSMutableArray array];

    [_valueArray enumerateObjectsUsingBlock:^(NSDictionary * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
        NSDictionary *dic = obj;

        [self.turnovers addObject:dic];
        [xValues addObject:dic[@"xLineValue"]];
        
        CGFloat a = [dic[@"yValue1"] floatValue];
        CGFloat b = [dic[@"yValue2"] floatValue];
        ChartDataEntry *entry1 = [[ChartDataEntry alloc] initWithX:idx y:a];
        ChartDataEntry *entry2 = [[ChartDataEntry alloc] initWithX:idx y:b];
        [yValues1 addObject:entry1];
        [yValues2 addObject:entry2];
    }];
    // 此处是用于处理只有一个点的情况。
    if (yValues1.count == 1) {
        ChartDataEntry *entry = yValues1[0];
        [yValues1 addObject:[[ChartDataEntry alloc] initWithX:entry.x + 1 y:entry.y]];
    }
    if (yValues2.count == 1) {
        ChartDataEntry *entry = yValues2[0];
        [yValues2 addObject:[[ChartDataEntry alloc] initWithX:entry.x + 1 y:entry.y]];
    }
    
    if (xValues.count == 1) {
        [xValues addObject:xValues[0]];
    }
    
    //设置横轴数据给chartview
    self.lineChartView.xAxis.valueFormatter = [[DateValueFormatter alloc]initWithArr:xValues];
    
    //创建LineChartDataSet对象
    LineChartDataSet *set1 = [[LineChartDataSet alloc] initWithValues:yValues1 label:@"label"];
    set1.valueColors = @[[UIColor clearColor]];
    set1.drawCirclesEnabled = false;
    set1.valueFont = [UIFont systemFontOfSize:12];
    set1.circleRadius = 0.5;
    set1.circleHoleRadius = 2.0;
    [set1 setColor:[UIColor redColor]];
    set1.mode = LineChartModeLinear;
    set1.drawValuesEnabled = true;
    
    LineChartDataSet *set2 = [[LineChartDataSet alloc] initWithValues:yValues2 label:@"label"];
    set2.circleRadius = 0.5;
    set2.circleHoleRadius = 2.0;
    [set2 setColor:[UIColor blueColor]];
    set2.mode = LineChartModeLinear;
    set2.drawValuesEnabled = NO;
    
    //sets内存放所有折线的数据 多个折线创建多个LineChartDataSet对象即可
    [sets addObject:set1];
    [sets addObject:set2];
    
    LineChartData *data = [[LineChartData alloc] initWithDataSets:sets];
    self.lineChartView.data = data;
}

-(void)chartValueSelected:(ChartViewBase *)chartView entry:(ChartDataEntry *)entry highlight:(ChartHighlight *)highlight {
//    NSLog(@"X值:%f  Y值:%ld", entry.y, (NSInteger)entry.x);
    _showLabel.text = [NSString stringWithFormat:@"X值:%f  Y值:%ld", entry.y, (NSInteger)entry.x];
}



@end


这里的样式是两条线,每多一条线就多加一个LineChartDataSet即可。点击对应的点返回数据的方法就是chartValueSelected,如果想给线添加别的样式,只要对应的加上formatter即可,这里暂时就不多说了。

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

推荐阅读更多精彩内容