iOS - PNChart

参考:
https://github.com/kevinzhow/PNChart
http://www.jianshu.com/p/fa8398e9ec62
http://blog.csdn.net/goyohol/article/details/53948983

这里写图片描述

#import "PNChart.h"

#define ARC4RANDOM_MAX      0x100000000

@interface ChartViewController ()
@property (nonatomic, strong) PNLineChart *lineChart;
@end

-(void)viewDidLoad {
    [super viewDidLoad];
    [self configureView];
    // Do any additional setup after loading the view.
}

-(void)configureView{
    [self.view addSubview:self.lineChart];
    [self setLineChart];
}

-(void)setLineChart{
    NSMutableArray *xLabelArray = [[NSMutableArray alloc] init];
    NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
    dateFormatter.dateFormat = @"HH:mm";
    for (int i = 0; i < 7; i++) {
        NSString *xLabelStr = [dateFormatter stringFromDate:[NSDate dateWithTimeInterval:i * 10 * 60 sinceDate:self.timePicker.date]];
        [xLabelArray addObject:xLabelStr];
    }
    [_lineChart setXLabels:xLabelArray];
    
    NSMutableArray *data01Array = [[NSMutableArray alloc] init];
    for (int i = 0; i < 7; i++) {
        double data = ((double)arc4random() / ARC4RANDOM_MAX) * 6.0f;
        [data01Array addObject:[NSNumber numberWithDouble:data]];
    }
    PNLineChartData *data01 = [[PNLineChartData alloc] init];
    data01.color = kDefaultColor;
    data01.inflexionPointColor = [UIColor whiteColor];
    data01.itemCount = _lineChart.xLabels.count;
    data01.getData = ^(NSUInteger index) {
        CGFloat yValue = [data01Array[index] floatValue];
        return [PNLineChartDataItem dataItemWithY:yValue];
    };
    data01.inflexionPointStyle = PNLineChartPointStyleCircle;
    data01.inflexionPointColor = kDefaultColor;
    
    NSArray * data02Array = @[@3.5, @3.5, @3.5, @3.5, @3.5, @3.5, @3.5];
    PNLineChartData *data02 = [[PNLineChartData alloc] init];
    data02.color = [UIColor redColor];
    data02.itemCount = _lineChart.xLabels.count;
    data02.getData = ^(NSUInteger index) {
        CGFloat yValue = [data02Array[index] floatValue];
        return [PNLineChartDataItem dataItemWithY:yValue];
    };
    
    _lineChart.chartData = @[data01, data02];
    [_lineChart strokeChart];
}

-(PNLineChart *)lineChart{
    if (!_lineChart) {
        _lineChart = [[PNLineChart alloc] initWithFrame:CGRectMake(0, SCREEN_HEIGHT / 9.2, SCREEN_WIDTH, SCREEN_HEIGHT / 2.4)];
        _lineChart.yLabelFormat = @"%1.1f";
        _lineChart.showSmoothLines = YES;
        _lineChart.showCoordinateAxis = YES;
        _lineChart.showYGridLines = YES;
        _lineChart.yGridLinesColor = [UIColor grayColor];
        _lineChart.axisColor = [UIColor blackColor];
    }
    return _lineChart;
}

这里写图片描述

#import "PNChart.h"

#define ARC4RANDOM_MAX      0x100000000

@interface ChartViewController ()
@property (nonatomic, strong) PNBarChart *barChart;
@end

-(void)viewDidLoad {
    [super viewDidLoad];
    [self configureView];
    // Do any additional setup after loading the view.
}

-(void)configureView{
    [self.view addSubview:self.barChart];
    [self setBarChart];
}

-(void)setBarChart{
    NSMutableArray *xLabelArray = [[NSMutableArray alloc] init];
    NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
    dateFormatter.dateFormat = @"MM-dd";
    for (int i = 0; i < 7; i++) {
        NSString *xLabelStr = [dateFormatter stringFromDate:[NSDate dateWithTimeInterval:i * 24 * 60 * 60 sinceDate:self.timePicker.date]];
        [xLabelArray addObject:xLabelStr];
    }
    [_barChart setXLabels:xLabelArray];

    NSMutableArray *yValueArray = [[NSMutableArray alloc] init];
    for (int i = 0; i < 7; i++) {
        double data = floorf(((double)arc4random() / ARC4RANDOM_MAX) * 60.0f);
        [yValueArray addObject:[NSNumber numberWithDouble:data]];
    }
    [_barChart setYValues:yValueArray];
    [_barChart strokeChart];
}

-(PNBarChart *)barChart{
    if (!_barChart) {
        _barChart = [[PNBarChart alloc] initWithFrame:CGRectMake(0, 0, SCREEN_WIDTH, 300)];
        _barChart.backgroundColor = [UIColor whiteColor];
        _barChart.showChartBorder = YES;
        _barChart.chartBorderColor = [UIColor blackColor];
        _barChart.strokeColor = kDefaultColor;
        _barChart.chartMarginLeft = 30.0;
        _barChart.chartMarginRight = 10.0;
        _barChart.chartMarginTop = 10.0;
    }
    return _barChart;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值