iOS卡顿优化

概述 

怎么优化下面场景离屏渲染的情况 图层阴影(Shadow):设置图层的 shadowOpacity、shadowOffset、shadowRadius 等属性。 图层圆角(Corner Radius):设置图层的 cornerRadius 属性,并同时启用了 masksToBounds。 图层蒙版(Mask):设置图层的 mask 属性或使用 maskToBounds。 透明度(Opacity):设置视图的 alpha 属性。

优化离屏渲染可以通过减少或避免导致离屏渲染的属性配置,或者通过替代性的方法来实现相同的视觉效果。以下是对每种情况的具体优化方法:

图层阴影(Shadow)

  • 问题:设置图层的 shadowOpacityshadowOffsetshadowRadius 等属性会触发离屏渲染,因为阴影需要在离屏缓冲区中计算和绘制。
优化方法:
  1. 预渲染阴影:如果阴影是静态的,可以预先将阴影绘制在一张图片上,然后在应用中直接使用这张图片。
  2. 使用更简单的阴影:尽量简化阴影效果,如减少阴影的模糊度或范围。
  3. 避免设置圆角和阴影同时存在:同时设置 cornerRadius 和阴影会导致更多的离屏渲染。可以考虑使用图片或者其他方式来模拟这种效果。

图层圆角(Corner Radius)

  • 问题:设置图层的 cornerRadius 属性,并同时启用 masksToBounds 会触发离屏渲染,因为图层需要在离屏缓冲区中进行剪裁和绘制。
优化方法:
  1. 使用 cornerRadius 而不启用 masksToBounds:只设置 cornerRadius 而不启用 masksToBounds 属性,这样不会触发离屏渲染,但适用范围有限。
  2. 使用 CAShapeLayer:通过 CAShapeLayer 创建圆角遮罩而不是直接使用 masksToBounds,可以减少离屏渲染的发生。
  3. 使用图片实现圆角:将圆角效果预先绘制在图片上,使用图片替代动态绘制的圆角效果。

图层蒙版(Mask)

  • 问题:设置图层的 mask 属性或使用 masksToBounds 会触发离屏渲染,因为图层需要在离屏缓冲区中进行剪裁和绘制。
优化方法:
  1. 简化蒙版图层:尽量简化蒙版的复杂度,减少蒙版的绘制计算量。
  2. 使用静态蒙版图片:将蒙版效果预先绘制在一张图片上,然后在应用中使用这张图片作为蒙版。
  3. 避免使用复杂的蒙版:尽量避免使用需要频繁更新或计算复杂的动态蒙版。

透明度(Opacity)

  • 问题:设置视图的 alpha 属性会触发离屏渲染,因为透明度需要在离屏缓冲区中进行混合计算。
优化方法:
  1. 减少透明视图层次:尽量减少设置透明度的视图层次,减少需要进行透明度混合计算的图层数量。
  2. 使用不透明背景色:尽量避免在大面积视图上使用透明度,可以使用带有不透明背景色的视图来替代。
  3. 合并透明视图:将多个透明视图合并为一个视图,减少离屏渲染的次数。

总结

通过减少或避免导致离屏渲染的属性配置,以及使用替代性的方法实现相同的视觉效果,可以有效优化应用的性能,减少卡顿和掉帧现象。以下是一个综合优化示例:

// 阴影优化
UIView *shadowView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)];
shadowView.layer.shadowColor = [UIColor blackColor].CGColor;
shadowView.layer.shadowOffset = CGSizeMake(0, 2);
shadowView.layer.shadowOpacity = 0.5;
shadowView.layer.shadowRadius = 4;
// 使用简单阴影效果或预渲染阴影图片// 圆角优化
UIView *cornerRadiusView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)];
cornerRadiusView.layer.cornerRadius = 10;
cornerRadiusView.clipsToBounds = YES;
// 使用CAShapeLayer替代
CAShapeLayer *shapeLayer = [CAShapeLayer layer];
shapeLayer.path = [UIBezierPath bezierPathWithRoundedRect:cornerRadiusView.bounds cornerRadius:10].CGPath;
cornerRadiusView.layer.mask = shapeLayer;// 蒙版优化
UIImageView *maskImageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"mask"]];
UIView *maskedView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)];
maskedView.layer.mask = maskImageView.layer;
// 使用静态蒙版图片替代// 透明度优化
UIView *alphaView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)];
alphaView.backgroundColor = [[UIColor redColor] colorWithAlphaComponent:0.5];
// 尽量减少透明视图层次或使用不透明背景色替代

通过合理的优化,可以显著提升 iOS 应用的流畅度和用户体验。

图层阴影(Shadow) 

设置图层的 shadowOpacity、shadowOffset、shadowRadius 等属性。 会导致离屏渲染吗?怎么优化?

设置图层的 shadowOpacityshadowOffsetshadowRadius 等属性会导致离屏渲染。这是因为阴影需要在离屏缓冲区中计算和绘制,这会增加 CPU 和 GPU 的负担,从而可能导致性能问题。以下是一些优化方法,可以帮助减少因阴影设置引起的离屏渲染开销:

优化方法

  1. 使用 shadowPath 属性

    • 通过设置 shadowPath 属性,可以告诉 Core Animation 阴影的形状。这样,系统不需要在每一帧都计算阴影的形状,从而避免

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/51440.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【保姆级讲解下QT6.3】

🎥博主:程序员不想YY啊 💫CSDN优质创作者,CSDN实力新星,CSDN博客专家 🤗点赞🎈收藏⭐再看💫养成习惯 ✨希望本文对您有所裨益,如有不足之处,欢迎在评论区提出…

【人工智能 | 机器学习 | 理论篇】线性模型

文章目录 1. 基本形式2. 线性回归3. 对数几率回归4. 线性判别分析5. 多分类学习6. 类别不平衡问题 1. 基本形式 设有 d 个属性描述的示例 x ( x 1 , x 2 , x 3 , . . . , x d ) x ({x_1, x_2, x_3, ..., x_d}) x(x1​,x2​,x3​,...,xd​) 线性模型(linear mode…

每天一个设计模式之命令模式(第二天)

交互模式中的命令模式,在开始记录之前,要讲些自己的感受,真真切切的感受到了悟性的瓶颈!一共十页书,需要自己细细琢磨品味,至少三四遍才大概了解了他们间的逻辑,我需要调整下自己的学习思路&…

使用 Vue 2.x + Element UI 搭建后台管理系统详解

引言 Vue.js 是一个非常流行的前端框架,而 Element UI 是基于 Vue 2.x 的一套完整的 UI 组件库,非常适合用来构建企业级的后台管理系统。本文将详细介绍如何使用 Vue 2.x 和 Element UI 来搭建一个后台管理系统,包括项目初始化、路由配置、状…

高级java每日一道面试题-2024年7月29日-并发篇-什么时候用乐观锁,什么时候用悲观锁?

面试官: 什么时候用乐观锁,什么时候用悲观锁? 我回答: 乐观锁和悲观锁是两种常用的并发控制策略,它们在多线程环境下用于保护共享资源免受并发修改的问题。下面我们将详细讨论这两种锁的使用场景和优缺点,以便你在实际开发中能够根据具体情况做出合适…

快速写一个Makefile

本文主要展示Makefile的基本要素和示例&#xff0c;让读者可以快速写出一个实用的Makefile。 简要说明 Makefile&#xff0c;GNU make命令工具。 书写格式 <target> : <prerequisites> [tab] <commands> <target> 文件名或某操作的名字&#xff0…

uniapp开发精选短视频视频小程序实战笔记20240725,实现顶部轮播图和热门短剧

创建项目 创建项目,叫video_app。 在pages.json里面修改一下标题: 新建search搜索页面和me我的页面。 此时界面预览效果如下: 引入静态资源 主要是static里面的内容,全部复制过来。 配置底部导航栏 pages.json,放到顶层,和全部样式同级: "tabBar&quo…

详细分析 Sql Server查询卡顿的排查方向

目录 前言1. 问题所示2. 原理分析2.1 缺乏索引2.2 表碎片2.3 查询计划缓存2.4 锁和阻塞 3. 总结 前言 本篇为理论知识的分析以及对症下药&#xff0c;前阵子发生过Bug&#xff0c;后通过迁移服务器以及数据库最终才解决问题&#xff0c;但是细想当时可能是因为碎片或者缓存的概…

WEBKIT 通过JavaScript 调用本地,硬件未来之窗OS硬件APP

以酒店为例我们需要调用shen份证读取&#xff0c;采集人脸&#xff0c;门锁写房卡&#xff0c;如何通过浏览器调用 1.通过本地http服务 2.通过webkit模式 这里说政务单位模式的集成 由于篇幅问题&#xff0c;怎么集成webkit就不说了 一、webkkit加载交互本地代码 browser.…

百日筑基第三十四天-JAVA中的强/软/弱/虚引用

百日筑基第三十四天-JAVA中的强/软/弱/虚引用 Java对象的引用被划分为4种级别&#xff0c;分别为强引用、软引用、弱引用以及虚引用。帮助程序更加灵活地控制对象的生命周期和JVM进行垃圾回收。 强引用 强引用是最普遍的引用&#xff0c;一般把一个对象赋给一个引用变量&…

23、Python之面向对象:实例属性、类属性,傻傻分不清楚

引言 在上一篇文章中&#xff0c;我们初步介绍了Python面向对象中类定义的语法&#xff0c;顺带介绍了关于面向对象的系统工程中&#xff0c;所涉及的OOA与OOD。 其实&#xff0c;简单来说&#xff0c;类的定义其实就是面向对象的“封装”特性的体现。我们将分析、设计得到的…

BLE自适应跳频算法详解

前言 &#xff08;1&#xff09;自适应跳频算法是相当的简单&#xff0c;小学生都能够看懂&#xff0c;而且网上已经有相当多的关于自适应跳频算法的介绍。既然如此&#xff0c;为什么我还要写这样一篇博客呢&#xff1f; &#xff08;2&#xff09;原因很简单&#xff0c;我发…

内网横向——利用WMI进行内网横向

文章目录 一、WMI介绍二、常规利用方法三、常见利用工具3.1 wmiexec3.2 Invoke-WmiCommand 四、WMI事件订阅的利用4.1 手动实现4.2 Sharp-WMIEvent 网络拓扑&#xff1a; 攻击机kali IP&#xff1a;192.168.111.0 跳板机win7 IP&#xff1a;192.168.111.128&#xff0c;192.168…

业务记录:处理动态表头的CSV/EXCEL文件

业务描述&#xff1a;传入一个动态表头的CSV文件&#xff0c;解析CSV&#xff0c;并保存入库。 CSV文件的表头是不确定的&#xff0c;即顺序和字段个数不确定&#xff0c;以及表头是中文字段。 例如&#xff1a; 为了顺利解析CSV文件&#xff0c;前端需要传入对应的字段名和顺…

.NET Core 命令大全

目录 1. 基本命令 2. 项目管理命令 3. 测试和调试命令 4. 包管理命令 5. 工具和扩展命令 结语 .NET Core 是一个跨平台、开源的开发平台&#xff0c;用于构建各种应用程序。为了方便开发者进行操作&#xff0c;.NET Core 提供了一系列的命令行工具。这篇文章将详细介绍这…

如何将anaconda的根环境复制到新环境

anaconda将根环境复制到新环境 在Anaconda中&#xff0c;您可以使用conda create命令来复制根环境到一个新的环境。以下是一个命令示例&#xff1a; conda create --name new_env --clone root 这里new_env是新环境的名字&#xff0c;您可以根据需要将其更改为您想要的名字。…

前端数据处理

数据处理 多字段&#xff08;数字类型&#xff09;排序 let arr [{name: jim, math: 85, english: 66, chinese: 36},{name: tom, math: 78, english: 70, chinese: 87},{name: lilei, math: 78, english: 89, chinese: 36},{name: alice, math: 90, english: 20, chinese: …

docker安装mysql遇到的问题

1、3306端口被占用 Error starting userland proxy: listen tcp4 0.0.0.0:3306: bind: address already https://blog.csdn.net/qq_42680327/article/details/136851627 2、mysql已经被占用 docker: Error response from daemon: Conflict. The container name “/mysql“ is…

使用SpringBoot集成Shardingjdbc介绍、应用场景和示例代码

概述 Spring Boot集成Sharding JDBC可以帮助实现MySQL数据库的分库分表操作&#xff0c;使得应用能够轻松处理大规模数据和高并发场景。Sharding JDBC通过透明的分库分表策略&#xff0c;将数据分布到多个数据库实例和数据表中&#xff0c;从而提高数据库的扩展性和性能。 应…

axure制作切换栏--动态面板的应用

先看下效果&#xff1a;点击上面的切换栏 切换到西游记栏目&#xff1a; 切换到水浒传栏目&#xff1a; 上述两个图片比对可以发现&#xff0c;在点击切换栏的时候&#xff0c;里面的内容以及切换栏的下面蓝色横线也会发生对应的变化。这里涉及到两个地方的变化&#xff0c;就…