效果图是这样的:

关键是在

基本策略 是描点 和 连线。

折线基础版本,我找到网上的第三方,UUChart 。 特点是朴素,简单,扩展性强。

效果图重点是在折线要有阴影,于是 重点 放在 折线发散的阴影 和 拆解第三方 整理出符合需求的面向对象良好的折线模型。

一 拆解:

分三个文件 HFChart,HFChartLineView,HFChartConst

HFChart : 折线视图控制器角色  控制展示数值范围,颜色,横线 等 必要UI 元素展示规则

HFChartConst : 折线需要展示的一些静态参数 比如 45设定为行间距 就可以设置在 Const 里面。

HFChartLine:  主要是实施绘制 描点 连线 和 绘制我们需要的阴影

二 阴影

说是阴影,实际 是颜色的渐变。

(1)之前 思考方向  这个阴影 是两点之间的连线 发散出来的, 就是这个执拗思路莫名把问题难度加大。因为 折线的若干个点,相邻 每两个点之间的连线都要有阴影 那么阴影方向? 阴影重叠? 等问题怎么解决? 越想越复杂

(2)从颜色渐变考虑

创建渐变图层,根据折线点,mask遮罩区域,剩下的渐变图层放在视图背景图上 就是阴影啦。有没有一种豁然开朗的感觉?

举例子:

(2.1)绘制渐变图层:CAGradientLayer  是用来绘制渐变图层的工具,作为关键字可以搜索到很多参考资料

    //实现背景渐变
//初始化我们需要改变背景色的UIView,并添加在视图上
self.theView = [[UIView alloc] initWithFrame:CGRectMake(0, 64, [UIScreen mainScreen].bounds.size.width, self.view.hf_width)];
[self.view addSubview:self.theView];
//初始化CAGradientlayer对象,使它的大小为UIView的大小
self.gradientLayer = [CAGradientLayer layer];
self.gradientLayer.frame = self.theView.bounds;
//将CAGradientlayer对象添加在我们要设置背景色的视图的layer层
[self.theView.layer addSublayer:self.gradientLayer];
//设置渐变区域的起始和终止位置(范围为0-1)
//不设置默认从上到下渐变,如果使用startPoint endPoint 就是右下角对角线 方向渐变 也可以自定义方向
// self.gradientLayer.startPoint = CGPointMake(0, 0);
// self.gradientLayer.endPoint = CGPointMake(1, 1);
//设置颜色数组(我写的是白色的渐变)
CGColorRef color1 = [UIColor colorWithWhite:1.000 alpha:0.7].CGColor;
CGColorRef color2 = [UIColor colorWithWhite:1.000 alpha:0.0].CGColor;
[_gradientLayer setColors:@[(__bridge id)color1,(__bridge id)color2]];//设置颜色分割点(范围:0-1)
self.gradientLayer.locations = @[@(0.0f), @(0.9f)];

效果图如下:(为了看清楚 白色的渐变遮罩 我选择了醒目的 紫色做背景色)

(2.2) 在知道已知点集(有序点 折点顺序)合添加遮罩方法

//给渐变层设置 mask 属性
{
// 设置只显示一个三角形范围的渐变色
UIBezierPath *shapeLayerPath = [[UIBezierPath alloc] init];
// 点的坐标是相对于渐变层的
[shapeLayerPath moveToPoint:CGPointMake(0,self.view.hf_width)];//第一个点
[shapeLayerPath addLineToPoint:CGPointMake(self.view.hf_width/2, 0)];//第二个点
[shapeLayerPath addLineToPoint:CGPointMake(self.view.hf_width, self.view.hf_width)];//第三个点
CAShapeLayer *shapeLayer = [CAShapeLayer layer];
shapeLayer.path = shapeLayerPath.CGPath;
self.gradientLayer.mask = shapeLayer;
}

效果图:

三 剩下的就是组织自己的折线模型结构了 已经是很简单了有没有?

整理HFChart HFChartConst HFChartLine 给 HFChartLine 添加遮罩 完成

参考 :

1 . https://github.com/ZhipingYang/UUChartView

2.http://www.jb51.net/article/79948.htm

iOS 绘制漂亮的折线图的更多相关文章

  1. IOS绘制渐变背景色折线图的一种尝试

    1.绘制折线图 上次在群里看到一个折线图划的很漂亮,自己想实现一个这样的 ,但是一直没什么头绪,不知道怎么做,就开始在网上查找划线,绘 制渐变色这一块的内容,用最笨的方式,自己尝试的写了一些,也没 有 ...

  2. 利用pandas读取Excel表格,用matplotlib.pyplot绘制直方图、折线图、饼图

    利用pandas读取Excel表格,用matplotlib.pyplot绘制直方图.折线图.饼图 数据: 折线图代码: import  pandas  as pdimport  matplotlib. ...

  3. iOS:使用贝塞尔曲线绘制图表(折线图、柱状图、饼状图)

    1.介绍: UIBezierPath :画贝塞尔曲线的path类 UIBezierPath定义 : 贝赛尔曲线的每一个顶点都有两个控制点,用于控制在该顶点两侧的曲线的弧度. 曲线的定义有四个点:起始点 ...

  4. [canvas]利用canvas绘制自适应的折线图

    前段时间学习了用canvas绘制折现图,且当画布变换大小,折现图会随之变化,现附上代码 <!DOCTYPE html> <html lang="en"> & ...

  5. C# 绘制统计图(柱状图, 折线图, 扇形图)【转载】

    统计图形种类繁多, 有柱状图, 折线图, 扇形图等等, 而统计图形的绘制方法也有很多, 有Flash制作的统计图形, 有水晶报表生成统计图形, 有专门制图软件制作, 也有编程语言自己制作的:这里我们用 ...

  6. C# 绘制统计图(柱状图, 折线图, 扇形图)

    统计图形种类繁多, 有柱状图, 折线图, 扇形图等等, 而统计图形的绘制方法也有很多, 有Flash制作的统计图形, 有水晶报表生成统计图形, 有专门制图软件制作, 也有编程语言自己制作的:这里我们用 ...

  7. IOS使用Core-Plot画折线图

    关于Core-Plot的配置.大家能够參考我的上一篇博客:http://1.wildcat.sinaapp.com/?p=99 版权全部.转载请注明原文转自:http://blog.csdn.net/ ...

  8. VS2010 使用TeeChart画图控件 - 之二 - 绘制图形(折线图,柱状图)

    1.前期准备 详细可见VS2010 使用TeeChart画图控件 - 之中的一个 控件和类的导入 1. 1 加入TeeChart控件,给控件加入变量m_TeeChart 加入TeeChart控件,右击 ...

  9. Python使用matplotlib模块绘制多条折线图、散点图

    用matplotlib模块 #!usr/bin/env python #encoding:utf-8 ''' __Author__:沂水寒城 功能:折线图.散点图测试 ''' import rando ...

随机推荐

  1. MySQL获取Schema表名和字段信息

    MySQL获取Schema表名和字段信息 获取表名 select TABLE_NAME,TABLE_TYPE,ENGINE,TABLE_ROWS,TABLE_COMMENT,CREATE_TIME,U ...

  2. CentOS上使用Squid+Stunnel搭建代理服务器教程

    这篇文章主要介绍了CentOS上使用Squid+Stunnel搭建代理服务器教程,同时文中也介绍了用户认证的方法,适合于多用户共同使用代理,这种功能在国内用还是比较exciting的~需要的朋友可以参 ...

  3. MAC信息摘要

    MAC(Message Authentication Code ,消息认证码算法)是含有密钥散列函数算法,兼容MD和SHA算法的特性,并在此基础上加入了密钥.因此,MAC也称为HMAC.       ...

  4. Windows中搭建ftp服务器

    使用工具Quick Easy FTP Server Windows中搭建FTP服务器有什么用呢? 确实没有用,直到有一次,我在VM中安装了Linux虚拟机,但是文件怎么也上传不到这个虚拟机中. 然后用 ...

  5. android自定义View_4——自定义属性的格式选择

    reference - if it references another resource id (e.g, "@color/my_color", "@layout/my ...

  6. ajax的适用场景

    1.适用:基本所有的网站都有涉及到. 2.典型使用场景: 动态加载数据,按照需要取数据 改善用户体验 电子商务应用 访问第三方服务 数据局部刷新

  7. JavaScript HTML DOM增删改查

    首先 js 可以修改HTML中的所有元素和属性,它还可以改变CSS样式,并且可以监听到所有事件并作出响应,这篇笔记呢 主要记录如何对HTML元素进行增删改查. 1 查找DOM 第一种方式是我们最常用的 ...

  8. zoj2770 Burn the Linked Camp --- 差分约束

    有n个营地,每一个营地至多容纳Ci人.给出m个条件:第i到第j个营地之间至少有k人. 问n个营地总共至少有多少人. 此题显然差分约束.要求最小值.则建立x-y>=z方程组,建图求最长路. 用d[ ...

  9. eclipse中如何查看一个android模拟器的内部文件

    eclipse中如何查看一个android模拟器的内部文件,有时要在其中添加一个文件夹或是什么的,要手动的做这件事,而不能够用代码去完成时,就要用这个方法了. 1.首先,打开一个安卓模拟器. 2.这个 ...

  10. 【BZOJ2282】[Sdoi2011]消防 树形DP+双指针法+单调队列

    [BZOJ2282][Sdoi2011]消防 Description 某个国家有n个城市,这n个城市中任意两个都连通且有唯一一条路径,每条连通两个城市的道路的长度为zi(zi<=1000). 这 ...