p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #1e9421 }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #000000; min-height: 16.0px }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #822d0f }
p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #c81b13 }
p.p5 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #3c828b }
p.p6 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #000000 }
p.p7 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #c42275 }
p.p8 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #6122ae }
p.p9 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #703daa }
p.p10 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #3e1e81 }
p.p11 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #539aa4 }
p.p12 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #294c50 }
span.s1 { }
span.s2 { font: 14.0px "PingFang SC" }
span.s3 { color: #0435ff }
span.s4 { color: #822d0f }
span.s5 { color: #c42275 }
span.s6 { color: #000000 }
span.s7 { color: #6122ae }
span.s8 { color: #703daa }
span.s9 { color: #3e1e81 }
span.s10 { color: #294c50 }
span.s11 { color: #539aa4 }
span.s12 { color: #78492a }

//

//  KCLWaveView.m

//  ButtonAnimation

//

//  Created by kcl on 2017/5/4.

//  Copyright © 2017年 KCL. All rights reserved.

//

#define BackGroundColor [UIColor colorWithRed:96/255.0f green:159/255.0f blue:150/255.0f alpha:1]

#define WaveColor1 [UIColor colorWithRed:136/255.0f green:199/255.0f blue:190/255.0f alpha:1]

#define WaveColor2 [UIColor colorWithRed:28/255.0 green:203/255.0 blue:174/255.0 alpha:1]

#import "KCLWaveView.h"

@interface KCLWaveView()

{

CAShapeLayer *_waveLayer1;

CAShapeLayer *_waveLayer2;

CADisplayLink *_disPlayLink;

CGFloat _waveAmplitude;

CGFloat _wavePalstance;

CGFloat _waveX;

CGFloat _waveY;

CGFloat _waveMoveSpeed;

}

//@property (nonatomic,strong)

@end

@implementation KCLWaveView

- (instancetype)initWithFrame:(CGRect)frame

{

self = [super initWithFrame:frame];

if (self) {

[self setUI];

[self buildData];

}

return self;

}

- (void)setUI{

_waveLayer1 = [CAShapeLayer layer];

_waveLayer1.fillColor = WaveColor1.CGColor;

_waveLayer1.strokeColor = WaveColor1.CGColor;

[self.layer addSublayer:_waveLayer1];

_waveLayer2 = [CAShapeLayer layer];

_waveLayer2.fillColor = WaveColor2.CGColor;

_waveLayer2.strokeColor = WaveColor2.CGColor;

[self.layer addSublayer:_waveLayer2];

self.layer.cornerRadius = self.bounds.size.width/2.0f;

self.layer.masksToBounds = YES;

self.backgroundColor = BackGroundColor;

}

- (void)buildData{

_waveAmplitude = 10;

_wavePalstance = M_PI/self.bounds.size.width;

_waveX = 0;

_waveY = 0;

_waveMoveSpeed = _wavePalstance *2;

_disPlayLink = [CADisplayLink displayLinkWithTarget:self selector:@selector(upDataWave:)];

[_disPlayLink addToRunLoop:[NSRunLoop mainRunLoop] forMode:NSRunLoopCommonModes];

}

- (void)upDataWave:(CADisplayLink *)link{

_waveX += _waveMoveSpeed;

[self updataWaveY];

[self updataWave1];

[self updataWave2];

}

- (void)updataWaveY{

CGFloat targetY = self.bounds.size.height - 0.3 * self.bounds.size.height;

if (_waveY < targetY) {

_waveY += 2;

}

if (_waveY > targetY ) {

_waveY -= 2;

}

}

- (void)updataWave1{

CGFloat waterWaveWidth = self.bounds.size.width;

CGMutablePathRef path = CGPathCreateMutable();

CGPathMoveToPoint(path, nil,0, _waveY);

CGFloat y = _waveY;

for (float x = 0.0f; x<= waterWaveWidth; x++) {

y = _waveAmplitude *cos(_wavePalstance*x +_waveX)+_waveY;

CGPathAddLineToPoint(path, nil, x, y);

}

CGPathAddLineToPoint(path, nil, waterWaveWidth, self.bounds.size.height);

CGPathAddLineToPoint(path, nil, 0, self.bounds.size.height);

CGPathCloseSubpath(path);

_waveLayer1.path = path;

CGPathRelease(path);

}

- (void)updataWave2{

CGFloat waterWaveWidth = self.bounds.size.width;

CGMutablePathRef path = CGPathCreateMutable();

CGPathMoveToPoint(path, nil,0, _waveY);

CGFloat y = _waveY;

for (float x = 0.0f; x<= waterWaveWidth; x++) {

y = _waveAmplitude *sin(_wavePalstance*x +_waveX)+_waveY;

CGPathAddLineToPoint(path, nil, x, y);

}

CGPathAddLineToPoint(path, nil, waterWaveWidth, self.bounds.size.height);

CGPathAddLineToPoint(path, nil, 0, self.bounds.size.height);

CGPathCloseSubpath(path);

_waveLayer2.path = path;

CGPathRelease(path);

}

- (void)dealloc{

[self stop];

if (_waveLayer1) {

[_waveLayer1 removeFromSuperlayer];

_waveLayer1 = nil;

}

if (_waveLayer2) {

[_waveLayer2 removeFromSuperlayer];

_waveLayer2 = nil;

}

}

- (void)stop{

if (_disPlayLink) {

[_disPlayLink invalidate];

_disPlayLink = nil;

}

}

/*

// Only override drawRect: if you perform custom drawing.

// An empty implementation adversely affects performance during animation.

- (void)drawRect:(CGRect)rect {

// Drawing code

}

*/

@end

CAShapeLayer+CADisplayLink 波浪动画的更多相关文章

  1. iOS CAShapeLayer、CADisplayLink 实现波浪动画效果

    iOS CAShapeLayer.CADisplayLink 实现波浪动画效果 效果图 代码已上传 GitHub:https://github.com/Silence-GitHub/CoreAnima ...

  2. Android 自定义波浪动画 --"让进度浪起来~"

    原文链接:http://www.jianshu.com/p/0e25a10cb9f5 一款效果不错的动画,实现也挺简单的,推荐阅读学习~ -- 由 傻小孩b 分享 waveview <Andro ...

  3. CAShapeLayer的path动画

    CAShapeLayer的path动画 效果 源码 https://github.com/YouXianMing/Animations // // CAShapeLayerPathController ...

  4. SVG波浪动画

    今天来试试用svg+css3制作波浪动画 下图是我制作出的效果 还不错吧 在制作波浪前,首先我们要画波浪啊,至于画波浪,如果你想直接通过计算贝塞尔曲线绘制出波浪... 好吧,那我也不拦着你 我就直接用 ...

  5. iOS高仿微信项目、阴影圆角渐变色效果、卡片动画、波浪动画、路由框架等源码

    iOS精选源码 iOS高仿微信完整项目源码 Khala: Swift 编写的iOS/macOS 路由框架 微信左滑删除效果的实现与TableViewCell的常用样式介绍 实现阴影圆角并存,渐变色背景 ...

  6. CADisplayLink+弹簧动画实现果冻效果

    项目中在Tabbar中间的按钮要从底部弹出视图并有果冻效果,在CocoaChina中找了一篇博客用 UIBezierPath 实现果冻效果,github,自己就按着上面的demo修改了一下( 之前也是 ...

  7. iOS | CAShapeLayer转场动画

    什么也不说了,作为一名乐于分享技术的小开发,直接先上个样式最为直观贴切,有需要的朋友可以直接拿过去用. 需要demo请点击这里 :github 在这个demo中,核心为选用画布CAShapeLayer ...

  8. android采用MVP漫画APP、适配刘海屏、小黄车主界面、录音波浪动画、综合APP等源码

    Android精选源码 一款采用MVP架构的仿完整漫画APP源码 Android适配刘海屏幕 基于Xmpp协议的即时通讯社交软件(客户端+服务端) Android小黄车(ofo)app主页菜单效果 一 ...

  9. css 实现水波纹,波浪动画效果

    <div class="wave"> 水波纹效果 <div class="wave1"></div> <div cla ...

随机推荐

  1. 如何在RecyclerView上面实现"拖放"和"滑动删除"-1

    Android上面有许多的教程, 库和示例, 在RecyclerView上面实现"拖放"和"滑动删除"功能. 尽管有更新, 更好的方法可用, 但是大多数人依然使 ...

  2. ABC: Always Be Coding

    ABC: Always Be Coding (原地址:https://medium.com/@davidbyttow/abc-always-be-coding-d5f8051afce2)   Be h ...

  3. mongoose简单使用样例

    新建文件 app.js 内容如下: var mongoose = require('mongoose') , Schema = mongoose.Schema; mongoose.connect('m ...

  4. PRINCE2的好处是什么?使用PRINCE2受益非浅

    项目管理促进了全球许多公共部门与私营企业的经济活动. 优秀的项目管理意味着使用更少的资源在更短的时间内达到一个成功的结果,经过良好培训的项目经理能够帮助组织更加富有创新力,取得成功. 对那些希望展现自 ...

  5. html实现 页面禁止右键 禁止复制 禁止图片拖动 禁止复制和剪切

    众所周知,一般的屏蔽的方法是用JS来编写的脚本,但是也可以直接通过修改网页属性的方法来屏蔽右键 禁止复制. 禁止右键 oncontextmenu="return false" 禁止 ...

  6. ASP.NET自定义模块

    要创建自定义模块,类需要实现IHttpModule接口.这个接口定义了Init和Dispose方法. Init方法在启动Web应用程序时调用,其参数的类型是HttpContext,可以添加应用程序处理 ...

  7. linux awk 命令详解

    awk是一个非常棒的数字处理工具.相比于sed常常作用于一整行的处理,awk则比较倾向于将一行分为数个"字段"来处理.运行效率高,而且代码简单,对格式化的文本处理能力超强.先来一个 ...

  8. c++中enum的用法——枚举类型

    将变量的可取值全部列举出来,写在程序的开头,使用该类型的时候显示地指定取值即可(即对枚举变量进行赋予元素操作,这里之所以叫赋元素操作不叫赋值操作就是为了说明枚举变量是不能直接赋予算数值的). 如: e ...

  9. Git托管

    前面的话 本文将主要介绍如何使用Github来托管Git服务 SSH 大多数Git服务器都会选择使用SSH公钥来进行授权.系统中的每个用户都必须提供一个公钥用于授权 首先先确认一下是否已经有一个公钥了 ...

  10. 跟着刚哥梳理java知识点——面向对象(八)

    面向对象的核心概念:类和对象. 类:对一类事物描述,是抽象的.概念上的定义. 对象:实际存在的该类事物的每个个体,因而也成为实例(Instance). Java类及类的成员:属性(成员变量Field) ...