将水波效果放在子视图上,主控制器只负责加载

#import "WaveProgress.h"

@interface WaveProgress ()

@property (nonatomic,assign)CGFloat yHeight;/**< 当前进度对应的y值,由于y是向下递增,所以要注意 */

@property (nonatomic,assign)CGFloat offset;/**< 偏移量,决定了这个点在y轴上的位置,以此来实现动态效果*/

@property (nonatomic,strong)CADisplayLink * link;/**< 定时器*/

@property (nonatomic,strong)CAShapeLayer * waveLayer;/**< 水波的layer */

@property (nonatomic,assign)CGFloat speed;/**< 波动的速度*/

@property (nonatomic,strong)UIColor * waveColor;

@property (nonatomic,assign)CGFloat waveHeight;

@end

@implementation WaveProgress

- (instancetype)initWithFrame:(CGRect)frame

{

self = [super initWithFrame:frame];

if (self) {

self.layer.borderColor = [UIColor lightGrayColor].CGColor;

self.layer.borderWidth = 1.0f;

self.waveHeight = 5.0;

self.speed = 1.0;

self.waveColor = [UIColor greenColor];

self.waveLayer = [CAShapeLayer layer];

self.waveLayer.frame = self.bounds;

self.waveLayer.fillColor = [UIColor whiteColor].CGColor;

[self.layer addSublayer:self.waveLayer];

//由于y坐标轴的方向是由上向下,逐渐增加的,所以这里对于y坐标进行处理

self.yHeight = self.bounds.size.height * 0.2;

//先停止动画,然后在开始动画,保证不会有什么冲突和重复.

[self stopWaveAnimation];

[self startWaveAnimation];

}

return self;

}

#pragma mark -- 开始波动动画

- (void)startWaveAnimation

{

//相对于NSTimer CADisplayLink更准确,每一帧调用一次.

self.link = [CADisplayLink displayLinkWithTarget:self selector:@selector(waveAnimation)];

[self.link addToRunLoop:[NSRunLoop currentRunLoop] forMode:NSRunLoopCommonModes];

}

#pragma mark -- 停止波动动画

- (void)stopWaveAnimation

{

[self.link invalidate];

self.link = nil;

}

#pragma mark -- 波动动画实现

- (void)waveAnimation

{

CGFloat waveHeight = self.waveHeight;

//如果是0或者1,则不需要wave的高度,否则会看出来一个小的波动.

//    if (self.progress == 0.0f || self.progress == 1.0f) {

//        waveHeight = 0.f;

//    }

//累加偏移量,这样就可以通过speed来控制波动的速度了.对于正弦函数中的各个参数,你可以通过上面的注释进行了解.

self.offset += self.speed;

CGMutablePathRef pathRef = CGPathCreateMutable();

CGFloat startOffY = waveHeight * sinf(self.offset * M_PI * 2 / self.bounds.size.width);

CGFloat orignOffY = 0.0;

CGPathMoveToPoint(pathRef, NULL, 0, startOffY);

for (CGFloat i = 0.f; i <= self.bounds.size.width; i++) {

orignOffY = waveHeight * sinf(2 * M_PI / self.bounds.size.width * i + self.offset * M_PI * 2 / self.bounds.size.width) + self.yHeight;

CGPathAddLineToPoint(pathRef, NULL, i, orignOffY);

}

//连接四个角和以及波浪,共同组成水波.

CGPathAddLineToPoint(pathRef, NULL, self.bounds.size.width, orignOffY);

CGPathAddLineToPoint(pathRef, NULL, self.bounds.size.width, self.bounds.size.height);

CGPathAddLineToPoint(pathRef, NULL, 0, self.bounds.size.height);

CGPathAddLineToPoint(pathRef, NULL, 0, startOffY);

CGPathCloseSubpath(pathRef);

self.waveLayer.path = pathRef;

self.waveLayer.fillColor = self.waveColor.CGColor;

CGPathRelease(pathRef);

}

@end

在主控制器中就懒加载一次就可以

- (WaveProgress *)progressView

{

if (!_progressView) {

_progressView = [[WaveProgress alloc]initWithFrame:CGRectMake(0, 0, self.view.frame.size.width, 150)];

}

return _progressView;

}

效果图如下

iOS 水波效果的更多相关文章

  1. 【转】提示框第三方库之MBProgressHUD iOS toast效果 动态提示框效果

    原文网址:http://www.zhimengzhe.com/IOSkaifa/37910.html MBProgressHUD是一个开源项目,实现了很多种样式的提示框,使用上简单.方便,并且可以对显 ...

  2. Android仿IOS回弹效果 ScrollView回弹 总结

    Android仿IOS回弹效果  ScrollView回弹 总结 应项目中的需求  须要仿IOS 下拉回弹的效果 , 我在网上搜了非常多 大多数都是拿scrollview 改吧改吧 试了一些  发现总 ...

  3. Android 实现高仿iOS桌面效果之可拖动的GridView(上)

    转载请标明出处:http://blog.csdn.net/sk719887916/article/details/40074663,作者:skay      最近项目中遇到一个LIstview的拖动效 ...

  4. iOS 波浪效果的实现

    iOS 波浪效果的实现 p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #4f8187; background-c ...

  5. canvas三角函数模拟水波效果

    .katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > ...

  6. Unity3D Shader水波效果

    水波效果 Shader "Custom/WaterWave" { Properties { _MainTex ("Base (RGB)", 2D) = &quo ...

  7. 使用js实现水波效果

    使用到的工具:jQuery Ripples Plugin 下载安装 git clone https://github.com/sirxemic/jquery.ripples.git 引入jquery, ...

  8. 【iOS系列】- iOS吸附效果的实现 之 UICollectionView的使用全解

    [iOS系列]- iOS吸附效果的实现 之 UICollectionView的使用全解 UICollectionView可以做很多的布局,在iOS开发中较为重要,所以这里就以实例来讲解UICollec ...

  9. css3之水波效果

    这些效果可谓多种多样,当然用canvas.svg也都能实现奈何对这些有不熟悉(尴尬),不过咱们用css来写貌似也没想象中的那么难吧. 一  悬浮球水波效果 效果图 css .container { w ...

随机推荐

  1. 关于WCF的一些知识点

    首先,WCF和WebService一些区别1,WCF支持多中通信协议,http/https tcp/udp/msmq.命名管道,对等网,消息可达性,事物流等.2,WCF可以与ASP.NET集成,共享同 ...

  2. 手机APP下单支付序列图

    今天安装了Visio,学习了下如何使用,画了一下公司现在项目的下单支付序列图,话就不多说了,直接上图,处女作,欢迎指正!

  3. rabbitmq-message(C#)

    1.安装Erlang Windows Binary File 2.安装rabbitmq-server(windows)rabbitmq-server-3.5.4.exe 参考:http://www.r ...

  4. rcp(插件开发) The activator X for bundle Y is invalid 解决办法

    最近在做插件产品的重构,重构的过程当中难免有一些细节的地方 忘记修改 ,导致出现莫名的问题. 比如这个问题: The activator X for bundle Y is invalid 这个问题从 ...

  5. Linux环境进程间通信(一):管道及命名管道

    linux下进程间通信的几种主要手段: 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允 ...

  6. C# 号码归属地查询算法

    C# 号码归属地查询算法(根据Android来电归属地二进制文件查询修改) 前言 近期有个项目需要用到号码归属查询,归属地数据库可能比不上ip138,淘宝上也有卖的-,-! 文本提供一个279188条 ...

  7. 【Hook技术】实现从"任务管理器"中保护进程不被关闭 + 附带源码 + 进程保护知识扩展

    [Hook技术]实现从"任务管理器"中保护进程不被关闭 + 附带源码 + 进程保护知识扩展 公司有个监控程序涉及到进程的保护问题,需要避免用户通过任务管理器结束掉监控进程,这里使用 ...

  8. Java 简单工厂模式

    首先 定义一接口 package com.org; public interface SampleInterface { public void print(String s); } 定义两个接口的实 ...

  9. javascript遍历select下拉框判断其中值是否与指定值相等

    用jquery多了,就忘了原生的js是如何写的了,还需要多加巩固. 需求:jsp回显一select下拉框.选中指定值. 用户点击修改 该select进行已有值回显.有两种解决方法 一.js中获取用户的 ...

  10. AOP的成员介绍

    AOP(Aspect Oriented Programming)面向切面编程,AOP的作用不过多介绍,本文是主要是介绍AOP的成员,是我在复习的时候记录的一些笔记,方便以后查阅方便一些. JointP ...