首先先看一下效果:

折线图

一、 初始化折线图对象

创建一个折线图的用到的类是LineChartView.h, 代码如下:

self.LineChartView = [[LineChartView alloc] init];

self.LineChartView.delegate = self;//设置代理

[self.view addSubview:self.LineChartView];

[self.LineChartView mas_makeConstraints:^(MASConstraintMaker *make) {

make.size.mas_equalTo(CGSizeMake(self.view.bounds.size.width-20, 300));

make.center.mas_equalTo(self.view);

}];

self.LineChartView.backgroundColor = [UIColor colorWithRed:230/255.0f green:253/255.0f blue:253/255.0f alpha:1];

self.LineChartView.noDataText = @"暂无数据";

二、设置折线图外观样式

1.设置交互样式

self.LineChartView.scaleYEnabled = NO;//取消Y轴缩放

self.LineChartView.doubleTapToZoomEnabled = NO;//取消双击缩放

self.LineChartView.dragEnabled = YES;//启用拖拽图标

self.LineChartView.dragDecelerationEnabled = YES;//拖拽后是否有惯性效果

self.LineChartView.dragDecelerationFrictionCoef = 0.9;//拖拽后惯性效果的摩擦系数(0~1),数值越小,惯性越不明显

2.设置X轴样式

ChartXAxis *xAxis = self.LineChartView.xAxis;

xAxis.axisLineWidth = 1.0/[UIScreen mainScreen].scale;//设置X轴线宽

xAxis.labelPosition = XAxisLabelPositionBottom;//X轴的显示位置,默认是显示在上面的

xAxis.drawGridLinesEnabled = NO;//不绘制网格线

xAxis.spaceBetweenLabels = 4;//设置label间隔

xAxis.labelTextColor = [self colorWithHexString:@"#057748"];//label文字颜色

3.设置Y轴样式

self.LineChartView.rightAxis.enabled = NO;//不绘制右边轴

ChartYAxis *leftAxis = self.LineChartView.leftAxis;//获取左边Y轴

leftAxis.labelCount = 5;//Y轴label数量,数值不一定,如果forceLabelsEnabled等于YES, 则强制绘制制定数量的label, 但是可能不平均

leftAxis.forceLabelsEnabled = NO;//不强制绘制指定数量的label

leftAxis.showOnlyMinMaxEnabled = NO;//是否只显示最大值和最小值

leftAxis.axisMinValue = 0;//设置Y轴的最小值

leftAxis.startAtZeroEnabled = YES;//从0开始绘制

leftAxis.axisMaxValue = 105;//设置Y轴的最大值

leftAxis.inverted = NO;//是否将Y轴进行上下翻转

leftAxis.axisLineWidth = 1.0/[UIScreen mainScreen].scale;//Y轴线宽

leftAxis.axisLineColor = [UIColor blackColor];//Y轴颜色

leftAxis.valueFormatter = [[NSNumberFormatter alloc] init];//自定义格式

leftAxis.valueFormatter.positiveSuffix = @" $";//数字后缀单位

leftAxis.labelPosition = YAxisLabelPositionOutsideChart;//label位置

leftAxis.labelTextColor = [self colorWithHexString:@"#057748"];//文字颜色

leftAxis.labelFont = [UIFont systemFontOfSize:10.0f];//文字字体

4.设置网格线样式

主要是设置Y轴的网格线样式, 代码如下:

leftAxis.gridLineDashLengths = @[@3.0f, @3.0f];//设置虚线样式的网格线

leftAxis.gridColor = [UIColor colorWithRed:200/255.0f green:200/255.0f blue:200/255.0f alpha:1];//网格线颜色

leftAxis.gridAntialiasEnabled = YES;//开启抗锯齿

5.添加限制线

限制线可以添加多条, 在这里只添加一条做演示, 代码如下:

ChartLimitLine *limitLine = [[ChartLimitLine alloc] initWithLimit:80 label:@"限制线"];

limitLine.lineWidth = 2;

limitLine.lineColor = [UIColor greenColor];

limitLine.lineDashLengths = @[@5.0f, @5.0f];//虚线样式

limitLine.labelPosition = ChartLimitLabelPositionRightTop;//位置

limitLine.valueTextColor = [self colorWithHexString:@"#057748"];//label文字颜色

limitLine.valueFont = [UIFont systemFontOfSize:12];//label字体

[leftAxis addLimitLine:limitLine];//添加到Y轴上

leftAxis.drawLimitLinesBehindDataEnabled = YES;//设置限制线绘制在折线图的后面

6.设置折线图描述及图例样式

当有多条折线显示在图表上时, 通常需要一个'图例'来说明每一条折线的名称或者代表的含义, 这时候就要进行图例的设置, 主要代码如下:

[self.LineChartView setDescriptionText:@"折线图"];//折线图描述

[self.LineChartView setDescriptionTextColor:[UIColor darkGrayColor]];

self.LineChartView.legend.form = ChartLegendFormLine;//图例的样式

self.LineChartView.legend.formSize = 30;//图例中线条的长度

self.LineChartView.legend.textColor = [UIColor darkGrayColor];//图例文字颜色

除了可以用以上这些属性来设置样式以外, 还有其它很多属性, 可以自行尝试. 由于以上这些属性较简单, 从属性名就可以看出其含义, 而且在代码后面也大都有注释, 在这里就不对这些属性作一一解释了.

三、为折线图提供数据

为折线图提供数据, 和柱形图差不多, 唯一不同的是设置折线图的折线线条样式, 在设置线条样式时, 我们可以设置折线的类型, 有阶梯类型和一般类型. 我们也可以设置折线拐点的样式, 拐点的大小, 拐点是否可以是空心类型等. 此外还可以对折线图进行颜色填充, 以此来美化图表. 由于样式太多, 在这里就不多说了, 直接看代码:

- (LineChartData *)setData{

int xVals_count = 12;//X轴上要显示多少条数据

double maxYVal = 100;//Y轴的最大值

//X轴上面需要显示的数据

NSMutableArray *xVals = [[NSMutableArray alloc] init];

for (int i = 0; i < xVals_count; i++) {

[xVals addObject:[NSString stringWithFormat:@"%d月", i+1]];

}

//对应Y轴上面需要显示的数据

NSMutableArray *yVals = [[NSMutableArray alloc] init];

for (int i = 0; i < xVals_count; i++) {

double mult = maxYVal + 1;

double val = (double)(arc4random_uniform(mult));

ChartDataEntry *entry = [[ChartDataEntry alloc] initWithValue:val xIndex:i];

[yVals addObject:entry];

}

LineChartDataSet *set1 = nil;

if (self.LineChartView.data.dataSetCount > 0) {

LineChartData *data = (LineChartData *)self.LineChartView.data;

set1 = (LineChartDataSet *)data.dataSets[0];

set1.yVals = yVals;

return data;

}else{

//创建LineChartDataSet对象

set1 = [[LineChartDataSet alloc] initWithYVals:yVals label:@"lineName"];

//设置折线的样式

set1.lineWidth = 1.0/[UIScreen mainScreen].scale;//折线宽度

set1.drawValuesEnabled = YES;//是否在拐点处显示数据

set1.valueColors = @[[UIColor brownColor]];//折线拐点处显示数据的颜色

[set1 setColor:[self colorWithHexString:@"#007FFF"]];//折线颜色

set1.drawSteppedEnabled = NO;//是否开启绘制阶梯样式的折线图

//折线拐点样式

set1.drawCirclesEnabled = NO;//是否绘制拐点

set1.circleRadius = 4.0f;//拐点半径

set1.circleColors = @[[UIColor redColor], [UIColor greenColor]];//拐点颜色

//拐点中间的空心样式

set1.drawCircleHoleEnabled = YES;//是否绘制中间的空心

set1.circleHoleRadius = 2.0f;//空心的半径

set1.circleHoleColor = [UIColor blackColor];//空心的颜色

//折线的颜色填充样式

//第一种填充样式:单色填充

// set1.drawFilledEnabled = YES;//是否填充颜色

// set1.fillColor = [UIColor redColor];//填充颜色

// set1.fillAlpha = 0.3;//填充颜色的透明度

//第二种填充样式:渐变填充

set1.drawFilledEnabled = YES;//是否填充颜色

NSArray *gradientColors = @[(id)[ChartColorTemplates colorFromString:@"#FFFFFFFF"].CGColor,

(id)[ChartColorTemplates colorFromString:@"#FF007FFF"].CGColor];

CGGradientRef gradientRef = CGGradientCreateWithColors(nil, (CFArrayRef)gradientColors, nil);

set1.fillAlpha = 0.3f;//透明度

set1.fill = [ChartFill fillWithLinearGradient:gradientRef angle:90.0f];//赋值填充颜色对象

CGGradientRelease(gradientRef);//释放gradientRef

//点击选中拐点的交互样式

set1.highlightEnabled = YES;//选中拐点,是否开启高亮效果(显示十字线)

set1.highlightColor = [self colorWithHexString:@"#c83c23"];//点击选中拐点的十字线的颜色

set1.highlightLineWidth = 1.0/[UIScreen mainScreen].scale;//十字线宽度

set1.highlightLineDashLengths = @[@5, @5];//十字线的虚线样式

//将 LineChartDataSet 对象放入数组中

NSMutableArray *dataSets = [[NSMutableArray alloc] init];

[dataSets addObject:set1];

//添加第二个LineChartDataSet对象

// LineChartDataSet *set2 = [set1 copy];

// NSMutableArray *yVals2 = [[NSMutableArray alloc] init];

// for (int i = 0; i < xVals_count; i++) {

// double mult = maxYVal + 1;

// double val = (double)(arc4random_uniform(mult));

// ChartDataEntry *entry = [[ChartDataEntry alloc] initWithValue:val xIndex:i];

// [yVals2 addObject:entry];

// }

// set2.yVals = yVals2;

// [set2 setColor:[UIColor redColor]];

// set2.drawFilledEnabled = YES;//是否填充颜色

// set2.fillColor = [UIColor redColor];//填充颜色

// set2.fillAlpha = 0.1;//填充颜色的透明度

// [dataSets addObject:set2];

//创建 LineChartData 对象, 此对象就是lineChartView需要最终数据对象

LineChartData *data = [[LineChartData alloc] initWithXVals:xVals dataSets:dataSets];

[data setValueFont:[UIFont fontWithName:@"HelveticaNeue-Light" size:8.f]];//文字字体

[data setValueTextColor:[UIColor grayColor]];//文字颜色

NSNumberFormatter *formatter = [[NSNumberFormatter alloc] init];

//自定义数据显示格式

[formatter setNumberStyle:NSNumberFormatterDecimalStyle];

[formatter setPositiveFormat:@"#0.0"];

[data setValueFormatter:formatter];

return data;

}

}

代理方法和其他图表一样,这里就不再赘述了.

运行结果如下:

运行结果

为折线图提供数据的用到的是LineChartData类创建的对象, 在LineChartData对象初始化时, 需要提供dataSets数组(里面放的是LineChartDataSet对象), 上面的例子中dataSets数组中只有一个LineChartDataSet对象, 也就是只有一条折线, 我们也可以在dataSets数组中放入多个LineChartDataSet对象, 也就是多条曲线, 下面的结果就是添加2条折线的效果, 如下图:

多条折线的折线图

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

ios 绘制线框_iOS使用Charts框架绘制折线图相关推荐

  1. python的matplotlib库绘制条形图、散点图、饼图、折线图

    python的matplotlib库绘制条形图.散点图.饼图.折线图 当我们学会了爬虫,抓取到了一些数据,接下来就是做数据分析了.本文章介绍绘制图形的基本代码. 打开cmd用pip 安装,若输入pip ...

  2. cahrt框架 ios_iOS使用Charts框架绘制—折线图

    首先先看一下效果: 折线图 一. 初始化折线图对象 创建一个折线图的用到的类是LineChartView.h, 代码如下: self.LineChartView = [[LineChartView a ...

  3. 用g.raphael.js高速绘制饼图、柱状图、点状图、折线图(下)

    首先,这里有个g.raphael.js的范例文章,可以直接看,我就不转载了: http://www.cnblogs.com/lhb25/archive/2013/01/09/gRaphael-java ...

  4. 用g.raphael.js高速绘制饼图、柱状图、点状图、折线图(上)

    首先介绍一下什么是g.raphael.这个又要说到什么是raphael.js.raphael是一个javascript库,可以用来跨浏览器绘制各种图形,只要是你想得到的图形都可以用raphael绘制出 ...

  5. python制作气温分布图_Python案例:查询城市天气并绘制最高气温与最低气温的折线图...

    1.编写源代码 - 查询城市天气. # -*- coding: utf-8 -*- """ Spyder Editor This is a temporary scrip ...

  6. Matlab论文插图绘制模板第74期—双对数刻度折线图(Loglog)

    在之前的文章中,分享了一系列Matlab折线图的绘制模板: ​ 这一次,再来分享一种特殊的折线图:双对数刻度折线图. 先来看一下成品效果: 特别提示:Matlab论文插图绘制模板系列,旨在降低大家使用 ...

  7. Matlab论文插图绘制模板第76期—半对数刻度折线图(Semilogx和Semilogy)

    在之前的文章中,分享了Matlab双对数刻度折线图的绘制模板: 进一步,再来分享一下半对数刻度折线图的绘制模板. 先来看一下成品效果: 特别提示:Matlab论文插图绘制模板系列,旨在降低大家使用Ma ...

  8. iOS使用Charts框架绘制—柱形图

    首先看一下最终要实现的效果: 最终效果 一.初始化barChartView 绘制柱形图需要用到BarChartView这个类,下面是初始化代码: self.barChartView = [[BarCh ...

  9. ios 绘制线框_iOS 各种边框

    UIView *View = [[UIView alloc] initWithFrame:(CGRectMake(0, 0, 100, 100))]; View.center = self.view. ...

最新文章

  1. 新发现:高速下载Eclipse
  2. CommunityServer研习心得(转)
  3. 比较好的电脑系统_win10电脑系统选择什么版本比较好
  4. mysql画事实表_sql生成事实表数据库
  5. cell重用的几种方式
  6. 两个数据集,本地可以关联,正式库关联不了
  7. C++class类(I)
  8. Java中的关键字this_super
  9. linux脚本编写思想,Linux脚本编写入门基础(三)
  10. 【计算机组成原理】英文选择题题库
  11. CoAP学习笔记——服务器端繁忙时的处理请求流程
  12. pandas 操作 excel
  13. iOS阶段学习第31天笔记(UINavigationBar介绍)
  14. 《数学建模与数学实验》第5版 统计分析 习题9.7
  15. linux安装工具的过程
  16. android 常用机型尺寸_android手机屏幕密度和逻辑尺寸
  17. STM32串口通信程序模拟超市打印机工作-使用接收中断、空闲中断、校验中断
  18. JPEG中Huffman解码实例讲解
  19. 阿里 P7 前端高级工程师,都需要掌握哪些技术栈?
  20. linux chsh命令参数及用法详解(linux设置系统shell命令) 详细出处参考:http://www.jb51.net/LINUXjishu/57945.html

热门文章

  1. 数学小天才游戏c语言,跪求C语言“数学小天才”小游戏 , 窗口将出现一个由数字组成的简单算...
  2. ios 仿电脑qq登录界面_高仿Windows Phone QQ登录界面实例代码
  3. Python:实现gaussian高斯算法(附完整源码)
  4. 和信创天云桌面系统VENGD文件上传漏洞复现
  5. 【33】警告Monitor thread (device: 1844301081AEE00F00 [2.4]) - ping was missed, closing the device connec
  6. 边玩游戏边学编程,怎么做到的?!
  7. 正规化缔合勒让德计算(标准前向列递推公式)
  8. Java官方文档居然挂羊头,卖狗肉,我的错?
  9. 自然语言处理入门学习系列一
  10. APISIX安装与灰度、蓝绿发布