iOS開發(fā)折線圖

我是自定義封裝了view, 用起來比較方便:
詳細(xì)代碼如下: (包括.h和.m文件)

// .h文件
#import <UIKit/UIKit.h>

@interface LineChartView : UIView

@property (nonatomic, strong) NSArray *titleForYArr;

@property (nonatomic, strong) NSArray *titleForXArr;

@property (nonatomic, strong) NSArray *valueArr;

@property (nonatomic, strong) UIColor *lineColor;

- (instancetype)initWithFrame:(CGRect)frame;

- (void)startDraw;

@end

// .m文件
#import "LineChartView.h"

@interface LineChartView()<CAAnimationDelegate>

@property (nonatomic, strong) CAShapeLayer *lineChartLayer;

@end

@implementation LineChartView {
    CGFloat width;
    CGFloat height;
}

static CGFloat edgeLeft = 30;
static CGFloat edgeRight = 20;
static CGFloat bounceY = 40;

static CGFloat edgeUp = 50;
static CGFloat edgeDown = 30;

- (instancetype)initWithFrame:(CGRect)frame {
    if (self = [super initWithFrame:frame]) {
        
        self.backgroundColor = [UIColor lightGrayColor];
        
        width = frame.size.width - edgeLeft - edgeRight;
        height = frame.size.height - edgeUp - edgeDown;
    }
    return self;
}
// 畫出坐標(biāo)軸
- (void)drawRect:(CGRect)rect {
    
    CGContextRef context = UIGraphicsGetCurrentContext();
    CGContextSetLineWidth(context, 1.0);
    CGContextSetRGBStrokeColor(context, 0.6, 0.6, 0.6, 1);
    CGContextMoveToPoint(context, edgeLeft, edgeUp);
    CGContextAddLineToPoint(context, edgeLeft, edgeUp + height);
    CGContextAddLineToPoint(context,edgeLeft + width, edgeUp + height);
    CGContextStrokePath(context);
}


#pragma mark 畫折線圖
- (void)dravLine{

    NSInteger yearNum = self.titleForXArr.count;
    if (yearNum <= 0) {
        return;
    }
    CGFloat widthForX = width / yearNum;
    CGFloat maxValue = [[self.titleForYArr lastObject] floatValue];
    
    if (maxValue <= 0) {
        return;
    }
    
    UIBezierPath *pathLine = [[UIBezierPath alloc] init];
    [pathLine moveToPoint:CGPointMake(edgeLeft + widthForX * 0.5, ((maxValue - [self.valueArr[0] floatValue]) / maxValue) * height + edgeUp)];
    
    // 創(chuàng)建折線點(diǎn)標(biāo)記
    for (NSInteger i = 1; i < self.valueArr.count; i++) {
        
        CGPoint pointCenter = CGPointMake(edgeLeft + widthForX * (i + 0.5), (maxValue - [self.valueArr[i] floatValue]) / maxValue * height + edgeUp);
        
        UIImageView *pointImg = [[UIImageView alloc] init];
        pointImg.bounds = CGRectMake(0, 0, 5, 5);
        pointImg.center = pointCenter;
        pointImg.backgroundColor = _lineColor;
        [self addSubview:pointImg];
        
        [pathLine addLineToPoint:pointCenter];
    }
    
    CAShapeLayer  *lineChartLayer = [CAShapeLayer layer];
    lineChartLayer.path = pathLine.CGPath;
    lineChartLayer.strokeColor = _lineColor.CGColor;
    lineChartLayer.fillColor = [[UIColor clearColor] CGColor];
    lineChartLayer.lineWidth = 2.0;
    lineChartLayer.lineCap = kCALineCapRound;
    lineChartLayer.lineJoin = kCALineJoinRound;
    
    [self.layer addSublayer:lineChartLayer];
}

#pragma mark 創(chuàng)建x軸的數(shù)據(jù)
- (void)setTitleForXArr:(NSArray *)titleForXArr {
    _titleForXArr = titleForXArr;
    [self createLabelX];
}
- (void)createLabelX{

    NSInteger yearNum = self.titleForXArr.count;
    if (yearNum <= 0) {
        return;
    }
    CGFloat widthForX = width / yearNum;
    
    for (NSInteger i = 0; i < yearNum; i++) {
        
        UILabel *labelYear = [[UILabel alloc] initWithFrame:CGRectMake(edgeLeft + widthForX * i, height + edgeUp, widthForX, edgeDown)];
        labelYear.tag = 1000 + i;
        labelYear.text = self.titleForXArr[i];
        labelYear.font = [UIFont systemFontOfSize:14];
        labelYear.textAlignment = NSTextAlignmentCenter;
        [self addSubview:labelYear];
    }
}
#pragma mark 創(chuàng)建y軸數(shù)據(jù)及虛線
- (void)setTitleForYArr:(NSArray *)titleForYArr {
    _titleForYArr = titleForYArr;
    [self createLabelY];
    [self setLineDash];
}
- (void)createLabelY{

    NSInteger numForY = _titleForYArr.count;
    if (numForY <= 1) {
        return;
    }
    CGFloat widthForY = edgeLeft;
    CGFloat heightForY = height / (numForY - 1);
    
    for (NSInteger i = 0; i < numForY; i++) {
        
        UILabel *labelForY = [[UILabel alloc] initWithFrame:CGRectMake(0, edgeUp + (i - 0.5) * heightForY, widthForY, heightForY)];
        
        labelForY.tag = 2000 + i;
        labelForY.text = _titleForYArr[numForY - i - 1];
        labelForY.font = [UIFont systemFontOfSize:12];
        labelForY.textAlignment = NSTextAlignmentCenter;
        [self addSubview:labelForY];
    }
}
#pragma mark - 添加虛線
- (void)setLineDash {
    
    NSInteger numForY = _titleForYArr.count - 1;
    if (numForY <= 0) {
        return;
    }
    CGFloat heightForY = height / numForY;
    
    for (NSInteger i = 0; i < numForY; i++) {
        
        CAShapeLayer *dashLayer = [CAShapeLayer layer];
        dashLayer.strokeColor = [UIColor colorWithRed:0.6 green:0.6 blue:0.6 alpha:1].CGColor;
        dashLayer.lineWidth = 1.0;
        
        UIBezierPath *path = [[UIBezierPath alloc] init];
        path.lineWidth = 1.0;
        
        [path moveToPoint:CGPointMake(edgeLeft, edgeUp + i * heightForY)];
        [path addLineToPoint:CGPointMake(edgeLeft + width, edgeUp + i * heightForY)];
        CGFloat dash[] = {10,10};
        [path setLineDash:dash count:2 phase:10];
        [path stroke];
        dashLayer.path = path.CGPath;
        [self.layer addSublayer:dashLayer];
    }
}
#pragma mark - 開始畫折線
- (void)startDraw {
    [self dravLine];
}

@end


// 使用方法
- (void)viewDidLoad {
    [super viewDidLoad];
    
    LineChartView *lineView = [[LineChartView alloc] initWithFrame:CGRectMake(0, 100, self.view.bounds.size.width, 190)];
    
    lineView.titleForYArr = @[@"0",@"1",@"2",@"3",@"4",@"5"];
    lineView.titleForXArr = @[@"2013年",@"2014年",@"2015年",@"2016年",@"2017年"];
    lineView.lineColor = [UIColor redColor];
    lineView.valueArr = @[@"0.8",@"1.9",@"4.0",@"1.3",@"2.5"];
    
    [self.view addSubview:lineView];
    
    [lineView startDraw];
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市麻削,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌顿锰,老刑警劉巖器赞,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件垢袱,死亡現(xiàn)場離奇詭異,居然都是意外死亡港柜,警方通過查閱死者的電腦和手機(jī)请契,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來夏醉,“玉大人爽锥,你說我怎么就攤上這事∨先幔” “怎么了氯夷?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長靶擦。 經(jīng)常有香客問我腮考,道長,這世上最難降的妖魔是什么玄捕? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任踩蔚,我火速辦了婚禮,結(jié)果婚禮上枚粘,老公的妹妹穿的比我還像新娘寂纪。我一直安慰自己,他們只是感情好赌结,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著孝冒,像睡著了一般柬姚。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上庄涡,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天量承,我揣著相機(jī)與錄音,去河邊找鬼穴店。 笑死撕捍,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的泣洞。 我是一名探鬼主播忧风,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼球凰!你這毒婦竟也來了狮腿?” 一聲冷哼從身側(cè)響起腿宰,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎缘厢,沒想到半個(gè)月后吃度,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡贴硫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年椿每,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片英遭。...
    茶點(diǎn)故事閱讀 38,018評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡间护,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出贪绘,到底是詐尸還是另有隱情兑牡,我是刑警寧澤,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布税灌,位于F島的核電站均函,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏菱涤。R本人自食惡果不足惜苞也,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望粘秆。 院中可真熱鬧如迟,春花似錦、人聲如沸攻走。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽昔搂。三九已至玲销,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間摘符,已是汗流浹背贤斜。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逛裤,地道東北人瘩绒。 一個(gè)月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像带族,于是被迫代替她去往敵國和親锁荔。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評論 2 345

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