iOS 双波浪动画-类似淘宝个人信息状态栏,京东金融等

类似淘宝个人信息状态栏,京东金融等双波浪动画

主要方法:通过自定义View,利用正弦函数与余弦函数的效果.

一.相关概念解释

正弦函数: y =Asin(ωx+φ)+C
A 表示振幅,也就是使用这个变量来调整波浪的高度
ω表示周期,也就是使用这个变量来调整在屏幕内显示的波浪的数量
φ表示波浪横向的偏移,也就是使用这个变量来调整波浪的流动
C表示波浪纵向的位置,也就是使用这个变量来调整波浪在屏幕中竖直的位置。

(1)利用CADisplayLink,进行UI的刷新.

@property (nonatomic,strong)CADisplayLink *wavesDisplayLink;
@property (nonatomic,strong)CAShapeLayer *firstWavesLayer;

iOS设备的屏幕刷新频率(FPS)是60Hz,因此CADisplayLink的selector 默认调用周期是每秒60次,这个周期可以通过frameInterval属性设置, CADisplayLink的selector每秒调用次数=60/ frameInterval。
比如当 frameInterval设为2,每秒调用就变成30次。

关于CADisplayLink,此处用NSTimer亦可.

(2)CAShapeLayer
CAShapeLayer 的对象是一个本身没有形状,他的形状来源于你给定的Path,它依附于path,所以必须给定path,即使path不完整也会自动收尾相接,strokeStart以及stroleEnd代表着这个path中所占的百分比(可以使用storkeStart和stroleEnd来做曲线进度的动画).

二.主要代码

(1)正弦与余弦函数

//创建一个路径
CGMutablePathRef path = CGPathCreateMutable();
CGFloat y = currentK;
//将点移动到 x=0,y=currentK的位置
CGPathMoveToPoint(path, nil, 0, y);
for (NSInteger i =0.0f; i<=WavesWidth; i++) {
    //正弦函数波浪公式
    y = waveA * sin(waveW * i+ offsetX)+currentK;
   //第二个View中:使用余弦函数波浪公式
   //y = waveA * cos(waveW * i+ offsetX)+currentK;
    //将点连成线
    CGPathAddLineToPoint(path, nil, i, y);
}

CGPathAddLineToPoint(path, nil, WavesWidth, 0);
CGPathAddLineToPoint(path, nil, 0, 0);

CGPathCloseSubpath(path);
self.firstWavesLayer.path = path;
//使用layer 而没用CurrentContext
CGPathRelease(path);
三.相关效果

1.正弦函数与余弦函数:相同速度/振幅/周期/非震荡效果

相同速度:振幅:周期:非震荡.gif

2.正弦函数与余弦函数:相同速度/振幅/周期/震荡效果,这就类似淘宝个人信息状态栏,余弦函数中加π/2即是峰顶与峰底对应效果*
相同速度:振幅:周期:震荡.gif

当速度/振幅/周期等改变时,会产生更多的效果:

3.正弦函数与余弦函数:不同速度/振幅,相同周期/非震荡效果,这个效果用起来也很不错
此处设置为:正弦与余弦函数参数不相同时,会产生交错效果;此处自行尝试更改即可产生不同动画效果.

正弦函数: 
//设置波浪流动速度
wavesSpeed = 0.02;
//设置振幅
waveA = 12;
//设置周期
waveW = 0.5/30.0

余弦函数: 
//设置波浪流动速度
wavesSpeed = 0.04;
//设置振幅
waveA = 13;
//设置周期
waveW = 0.5/30.0;

不同速度:振幅,相同周期非震荡.gif

4.正弦函数与余弦函数:不同速度/振幅,相同周期/震荡效果
不同速度:振幅,相同周期:震荡.gif

5.正弦函数与余弦函数:不同速度/振幅,相同周期/,峰顶与峰底对应效果,可自行开启震荡
更改余弦函数公式为:

//如果需要正弦函数的峰顶和余弦函数的峰底对应,可以替换成下方公式均可
//y = waveA * cos(waveW*i + offsetX+M_PI_2)+currentK;  
//y = waveA * sin(-(waveW*i + offsetX))+currentK;
同速度:振幅:周期,峰顶与峰底对应.gif

6.正弦函数与余弦函数:如果需要让双波浪在屏幕下方显示
更改代码为:
以第一个波浪为例,第二个同理更改就行.

//第一个波浪
self.firstWare = [[FirstWaves alloc]initWithFrame:CGRectMake(0, self.view.frame.size.height-200, self.view.frame.size.width, 220)];

//波浪公式下方更改
CGPathAddLineToPoint(path, nil, WavesWidth, self.frame.size.height);
CGPathAddLineToPoint(path, nil, 0, self.frame.size.height);
屏幕下方显示.png
四.Demo地址

欢迎star : https://github.com/FTC-Chen/DoubleWavesAnimation

五.参考资料

1.http://blog.csdn.net/u010123208/article/details/51227035
2.http://www.tuicool.com/articles/meMVR3

有任何问题请私信或者留言,或者有更好的实现方法,也请告诉我.

最後編輯於
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama閱讀 214,128評論 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama閱讀 91,316評論 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人閱讀 159,737評論 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人閱讀 57,283評論 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事閱讀 66,384評論 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人閱讀 50,458評論 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama閱讀 39,467評論 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人閱讀 38,251評論 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama閱讀 44,688評論 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事閱讀 36,980評論 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事閱讀 39,155評論 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama閱讀 34,818評論 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事閱讀 40,492評論 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人閱讀 31,142評論 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人閱讀 32,382評論 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama閱讀 47,020評論 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事閱讀 44,044評論 2 352

推薦閱讀更多精彩內容