iOS 滑动性能优化

iOS 滑动性能优化

目录

  • 一、 减少图层的Blend操作

    • 1. UIView的背景色避免使用clearColor
    • 2. 控件贴图避免使用带alpha的图片
    • 3. UIImageView 使用时避免半透明
  • 二、适当使用Rasterize
  • 三、避免图片资源的重采样
  • 总结
  • 更多参考资料

一、 减少图层的Blend操作

展示半透明的view,设备会把当前图层和背景图层进行alpha叠加,这是一项很耗性能的一件事。如果动画中每一帧都做叠加,性能的损耗是很严重。

1. UIView的背景色避免使用clearColor

  • UIView记得设置成和SuperView相同的颜色

动作虽小,效果却好 
尤其是在需要滑动的场景

2. 控件贴图避免使用带alpha的图片

  • 视觉给出的贴图最好不带Alpha通道
  • 如果必须使用Alpha,则主动去Alpha,提前和背景色合成为不含Alpha的图片

针对同一场景图片合成只需要做一次 
一次合成,长期使用

3. UIImageView 使用时避免半透明

Disable alpha blending except where needed. Unless you are intentionally working with images that contain transparency (drawing UI elements, for example), you should generally mark the view as opaque by checking Opaque checkbox in the attributes inspector, or setting the opaque property on the view itself.

UIImageView的半透明取决于以下几项:

  • 显示的图片
  • View的opaque属性的值
  • View的alpha值
  • View的背景色

An opaque view is expected to fill its bounds with entirely opaque content—that is, the content should have an alpha value of 1.0. If the view is opaque and either does not fill its bounds or contains wholly or partially transparent content, the results are unpredictable. You should always set the value of this property to NO if the view is fully or partially transparent.

规则如下:

  • 当Opaque属性为YES的时候,imageView的alpha属性会被忽略,图层是否半透明取决于图片和imageView本身的背景色的叠加结果。

    • 如果叠加结果图全部不透明,则图层不透明,不会触发blend操作。
    • 如果叠加结果中出现半透明区域,则整个图层都会变成不透明,会触发blend操作。
  • 如果Opaque属性为NO的时候,图层是否半透明取决于图片和imageView的multiplied叠加结果确定。

简单理解,如果可能尽量:

  • 设置Opaque为YES
  • 背景色设置为不含alpha的颜色
  • alpha值最好也是1(不透明)。

适用场景

  • 通用优化规则,不会造成副作用

二、适当使用Rasterize

针对内容比较固定的Cell,建议采用光栅化,让Core Animation框架帮我们完成图层的混合,生成一个静态图,优化帧率。

适用场景

  • UITableView & UICollectionView & UIScrollView中内容变化不频繁的Cell

注:此优化需要Profile,使用Core Animation工具中的“ColorHitsGreenandMissesRed”工具调优 
如果使用不当,可能适得其反

三、避免图片资源的重采样

Image views can perform two operations that are relatively expensive performance-wise: scaling the image and alpha compositing the image with lower layers.

减少图片资源的重采样是一个费时给力的过程,涉及到插值算法,以双线性插值为例,每插值一个点需要用到周围四个点的像素值,运算量可见一斑。

直接对于UIImageView设置一个大图,在实际展示的时候会在主线程完成重采样的过程,耗时耗内存。

如何避免?

  • 网络图片资源

    • 请求接口时,服务端根据场景返回尺寸尽可能接近展示的图片资源。

    此举既可以节省流量,又可以节省重采样的时间。

  • 本地图片资源
    • 有可能的话,针对不同场景放置多个尺寸的图片资源
    • 针对应用场景生成一个适用于使用场景尺寸的图片资源,并在该场景中生成的图片

适用场景

  所有需要使用图片的场景都可以使用此方案优化,无副作用。

总结

  滑动性能优化这块儿涉及到的知识还是挺多的,不要盲目,过早的优化。使用Instrument找出瓶颈,然后合理使用不同的方案。性能优化有很多奇淫技巧,但通常做到上面几个大的点,基本上性能就能接受了。

  对于TableView & Collection View这块儿还有一个很有效的优化手段,在快速滑动的时候,忽略中间快速闪过的Cell,直接借用UIScrollView的delegate判断加载滑动停止目标区域的Cell的内容。实践证明此方法效果还是很明显的,具体例子可以网上搜一下。

Profile -> 优化 -> Profile

  一直重复上面的流程,直到达到预期为止。

  最后重要的事情说三遍:

  Profile一定请使用真机,最好使用Release模式,以达到最真实的效果。
  Profile一定请使用真机,最好使用Release模式,以达到最真实的效果。
  Profile一定请使用真机,最好使用Release模式,以达到最真实的效果。

更多参考资料:

注:smileEvday保留本文的一切权利

  转载请著名原文出处

  本文所有内容仅代表个人观点,如有有不对的地方,欢迎指出。

时间: 2024-08-13 02:59:25

iOS 滑动性能优化的相关文章

iOS性能优化:Instruments使用实战

iOS性能优化:Instruments使用实战 最近采用Instruments 来分析整个应用程序的性能.发现很多有意思的点,以及性能优化和一些分析性能消耗的技巧,小结如下. Instruments使用技巧 关于Instruments官方有一个很有用的用户使用Guide,当然如果不习惯官方英文可以在这里找到中文本翻译版本PDF参阅.Instruments 确实是一个很强大的工具,用它来收集关于一个或多个系统进程的性能和行为的数据极为方便,并能及时跟踪随着时间产生的数据.还可以广泛收集不同类型的数

Unity3d iOS基本优化和高级优化

原地址:http://www.cocoachina.com/bbs/read.php?tid=70395&page=1 分享看见的2篇好文.简单翻译了一下并且放出原文http://www.cratesmith.com/archives/1831.做减法大量代码在Update()或FixedUpdate()中做处理,意味着无论代码的执行速度如何,都将在每次帧刷新的时候调用到, 复制代码 public class MyHoming : MonoBehaviour { public void Upda

iOS性能优化小结

iOS性能优化分析 首先要熟悉几个概念 PNG 和 JPG 的区别是什么? png格式的图片有alpha通道,jpeg则没有.png无损压缩,jpeg允许你选择0-100%的压缩质量.如果需要alpha通道(透明),就只能用png格式. CPU 和 GPU 如果想看看两者的区别,先得了解iOS视图背后的层级结构原理  上图中的最底下一行是硬件层,由GPU和CPU组成. 我们经常说到的硬件加速其实是指OpenGL,Core Animation/UIKit基于GPU之上对计算机图形合成以及绘制的实现

IOS 性能优化的建议和技巧

IOS 性能优化的建议和技巧 本文来自iOS Tutorial Team 的 Marcelo Fabri,他是Movile的一名 iOS 程序员.这是他的个人网站:http://www.marcelofabri.com/,你还可以在Twitter上关注@marcelofabri_. 性能对 iOS 应用的开发尤其重要,如果你的应用失去反应或者很慢,失望的用户会把他们的失望写满App Store的评论.然而由于iOS设备的限制,有时搞好性能是一件难事.开发过程中你会有很多需要注意的事项,你也很容易

【腾讯Bugly干货分享】微信读书iOS性能优化

本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/578c93ca9644bd524bfcabe8 "8小时内拼工作,8小时外拼成长"这是大家共同的理想.除了每天忙于工作外,我们都希望能更多地区吸收领域内的新知识与新技能,从而走向人生巅峰. Dev Club 是一个交流移动开发技术,结交朋友,扩展人脉的社群,成员都是经过审核的移动开发工程师.每周都会举行嘉宾分享,话题讨论等活动. 上一期我们邀请了腾讯SNG工程师&qu

iOS性能优化技巧

iOS性能优化技巧 通过静态 Analyze 工具,以及运行时 Profile 工具分析性能瓶颈,并进行性能优化.结合本人在开发中遇到的问题,可以从以下几个方面进行性能优化. 一.view优化 1.不透明的View 设置为opaque. 2.根据实际情况重用.延迟加载或预加载View. 3.减少subviews数量,定制复杂cell使用drawRect.尽量使用drawRect而不是layoutSubView. 4.不直接调用drawRect. layoutSubviews方法.万不得已时可以用

iOS性能优化之“优化总体原则”(性能优化很重要,为什么你们都没有用?)

笔者由于在iOS开发过程中做过一些优化的工作,对iOS性能优化有一些粗浅的认识,一直想把自己这些经验,简单总结一下. 作为整个系列的第一篇,我打算针对iOS的优化中的一些总体原则做一些总结.因为我觉得无论列表流畅度优化也好.启动时间优化也好还是说其他方面的优化,都有一些共性的原则,只有掌握了这些总体性的原则,才能够更好的做优化,给我们具体的优化任务指明方向,让我们少绕弯路.后面如果时间允许,我可能会写一些关于列表流畅度.启动时间和内存优化等方面的文章. 作为一个开发者,有一个学习的氛围跟一个交流

iOS性能优化之Leaks动态分析

iOS性能优化之Leaks动态分析 Instruments-Leaks有很多跟踪模块可以动态分析和跟踪内存, CPU 和文件系统(因为是动态分析 所以必须运行才能打开). 具体使用 在XCode Open菜单下,点击Leaks 对App进行动态分析(快捷键CMD + i) 或者直接在工程中选择调试导航 在右侧点击Profile in instruments 检测图: Separate by Thread:按线程分开做分析,这样更容易揪出那些吃资源的问题线程.特别是对于主线程,它要处理和渲染所有的

iOS 性能优化收集

iOS 性能调试 instrument Instrument Instrument之Core Animation工具 避免图层混合 ①.确保控件的opaque属性设置为true,确保backgroundColor和父视图颜色一致且不透明: ②.如无特殊需要,不要设置低于1的alpha值: ③.确保UIImage没有alpha通道: 避免临时转换 ①.确保图片大小和frame一致,不要在滑动时缩放图片: ②.确保图片颜色格式被GPU支持,避免劳烦CPU转换: 慎用离屏渲染 ①.绝大多数时候离屏渲染