iOS实现百度外卖头像波浪的效果

 更新时间:2016年08月28日 09:47:50   投稿:daisy  
对于现在很多人来说,叫外卖就成了不可或缺的习惯。某日瞬间发现百度外卖的APP波浪效果很是吸引人,相比较其他的外卖APP,颜值略高些.(淘宝也有波浪的效果),遂就思考如何实现这种"浪"的效果,下面来一起看看。

效果演示

百度外卖 波浪效果图:


你需要知道的

CADisplayLink

简单的说就是一定时器,其根本利用刷帧和屏幕频率一样来重绘渲染页面.

其创建方式:

CADisplayLink *timer = [CADisplayLink displayLinkWithTarget:self selector:@selector(wave)];
[timer addToRunLoop:[NSRunLoop currentRunLoop] forMode:NSRunLoopCommonModes];

CAShapeLayer

CALayer的子类,通常结合CGPath来绘制图形.

其创建方式:

CAShapeLayer *Layer = [CAShapeLayer layer];
Layer.frame = self.bounds;
Layer.fillColor = self.realWaveColor.CGColor;
Layer...等属性
[self.view.layer addSublayer:Layer];

其优点

渲染效率高渲染快速。CAShapeLayer使用了硬件加速,绘制同一图形会比用Core Graphics快很多。

高效使用内存。一个CAShapeLayer不需要像普通CALayer一样创建一个寄宿图形,所以无论有多大,都不会占用太多的内存。

不会被图层边界剪裁掉。一个CAShapeLayer可以在边界之外绘制。你的图层路径不会像在使用Core Graphics的普通CALayer一样被剪裁掉。

不会出现像素化。当你给CAShapeLayer做3D变换时,它不像一个有寄宿图的普通图层一样变得像素化。

三角函数

思路实现

UIView --> 2个CAShapeLayer --> imageView.frame.orgin.y调整

主要代码实现


最后效果:

以上就是本文的全部内容,希望对大家开发IOS能有所帮助。如果有疑问可以留言讨论。

相关文章

  • iOS体验性优化之RTL适配右滑返回的实现

    iOS体验性优化之RTL适配右滑返回的实现

    这篇文章主要给大家介绍了关于iOS体验性优化之RTL适配右滑返回实现的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-01-01
  • iOS AVPlayer切换播放源实现连续播放和全屏切换的方法

    iOS AVPlayer切换播放源实现连续播放和全屏切换的方法

    这篇文章主要给大家介绍了关于iOS中AVPlayer切换播放源实现连续播放和全屏切换的方法,文中给出了详细的示例代码供大家参考学习,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-05-05
  • iOS UITextField最大字符数和字节数的限制详解

    iOS UITextField最大字符数和字节数的限制详解

    在开发中我们经常遇到这样的需求:在UITextField或者UITextView中限制用户可以输入的最大字符数。但在UITextView , UITextfield 中有很多坑,网上的方法也很多。但是并不是很全面吧,这里全面进行了总结,有需要的朋友们可以参考借鉴,下面跟着小编一起来学习学习吧。
    2016-11-11
  • IOS 九宫格布局实现方法

    IOS 九宫格布局实现方法

    这篇文章主要介绍了IOS 九宫格布局实现方法,及实例代码,需要的朋友可以参考下
    2016-09-09
  • IOS实现签到特效(散花效果)的实例代码

    IOS实现签到特效(散花效果)的实例代码

    这篇文章主要介绍了IOS实现签到特效(散花效果)的实例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • 如何去掉Xcode工程中某种类型的警告

    如何去掉Xcode工程中某种类型的警告

    这篇文章主要给大家介绍了关于如何去掉Xcode工程中某种类型的警告,文中通过示例代码介绍的非常详细,对大家学习或者使用Xcode具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • iOS使用UIScrollView实现无限循环轮播图效果

    iOS使用UIScrollView实现无限循环轮播图效果

    这篇文章主要介绍了iOS使用UIScrollView实现无限循环轮播图效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • 讲解iOS开发中基本的定位功能实现

    讲解iOS开发中基本的定位功能实现

    这篇文章主要介绍了讲解iOS开发中基本的定位功能实现,示例基于传统的Objective-C,需要的朋友可以参考下
    2015-10-10
  • IOS Cache设计详细介绍及简单示例

    IOS Cache设计详细介绍及简单示例

    这篇文章主要介绍了IOS Cache设计详细介绍及简单示例的相关资料,Cache的目的是为了追求更高的速度体验,Cache的源头是两种数据读取方式在成本和性能上的差异,需要的朋友可以参考下
    2017-01-01
  • 设计模式中的迭代器模式在Cocoa Touch框架中的使用

    设计模式中的迭代器模式在Cocoa Touch框架中的使用

    这篇文章主要介绍了设计模式中的迭代器模式在Cocoa Touch框架中的使用,示例代码为传统的Objective-C,需要的朋友可以参考下
    2016-03-03

最新评论