性能优化之资源优化

性能优化之资源优化

  • 资源优化
    • 性能关键检测流程。
    • 浅析一下基于Unity3D 美术规则约束
      • 一、模型层面
      • 二、贴图层面
      • 三、动画层面
      • 四、声音层面:(音频通用设置)
      • 五、UI层面:
    • 题外点:诚然在优化中,美术占比是很重要的,所以咱们从理论上再来理解一下美术制作流程。

资源优化

我们都知道,制作游戏应用,性能优化总是老生常谈的问题。也许我们可能会从CPU(复杂的计算、物理模拟)、GPU(过多的顶点计算等)入手定位考虑,但是真正落实的优化还得从项目具体情况决定,并且在优化过程中,我们需要懂得善用工具,如Unity Profiler、UWA、URP等相关性能工具。另外我们还得远离那些奇怪的想法,觉得性能优化应该是属于游戏应用的最后一道环节,所以导致在实际项目优化时会感觉特别的痛苦和无力,例如,优化中涉及美术资源的修改的,而美术资源一旦涉及需要修改,就相当于面临资源重做的成本,所以项目优化应该从项目立项需求设计、资产制作环节、架构设计等环节就开始, 并尽早验证核心玩法性能,才能成就出一款优质的应用产品。

性能关键检测流程。

在这里插入图片描述

浅析一下基于Unity3D 美术规则约束

一、模型层面

1、模型比例,严格遵循模型与模型之间,模型场景之间的比例要正确统一(单位和比例),模型坐标统一为原点。
2、减面操作,主要是去掉对模型造型没有影响的⾯,⽤尽可能少的⾯数表达清楚模型的结构和造型。⽐如:物件⾮关节点及物件背⾯、内部不会看见的⾯删掉。
3、减少模型顶点的数量,模型顶点的数量会影响GPU的性能,所有物体不超过20000个三角面,人模模型面数控制在3000-4000面,移动端单个人体骨骼数量控制在30个~50个左右。
4、合并模型,合并同⼀⼩范围内的⾮交互类的静态⼩物件,同时合并⼩物件的贴图。这样可以减少Draw Call的数量。如,⼀组不同⼤⼩的⼩草,⼀组⼤⼩形状不同的⽯头,⼀个书架和上⾯放置的很多书籍等。把这些⼩物件合并成⼀个Object,贴图也合成成⼀张贴图。
5、模型的重复利⽤,相同的多个物件在Unity内复制使⽤,复制的多个物体在引擎计算上算⼀个物体。但也不可复制太多个,太多会对内存带来很⼤压⼒。相同的物件太多,建议把⼏个合并成⼀组做为⼀个Object,多做⼏组,再进⾏复制。
6、减少模型UV接缝和硬边的数量
7、减少Material的数量,实际上一个模型至少需要一张贴图,如果可能,可以将多张贴图拼成一张贴图,这样多个模型可以共享同一个Material。
8、尽可能减少像素灯光、阴影、反射的使用,这些功能会导致模型被渲染多次,加重CPU的负担。
9、地形优化,如果是⽤unity⾃带的地形⼯具制作的地形,可以⽤T4M插件转化成T4M格式地形,设置⼀个顶点值转化后可以对地形优化很多。T4M也可以设置Lod模型。
10、FBX资源中有太多的顶点, 请检查是否必要Custom Parameters: VertexCountLimit : 500,(顶点数一般限制为500)在满足美术效果下,尽量减少顶点数。
11、检查文件Mesh读/写标记,默认关闭。在这里插入图片描述
12、资源根据国内标准(参考UWA):低端、中端、高端设备建议总面数控制在30w, 40w ,50w。Unity手游性能白皮书

二、贴图层面

1、贴图⼤⼩,在移动设备上的贴图最⼤要控制在1024和512⼤⼩,可少量使⽤2048⼤⼩的贴图,以1024、512⼤⼩贴图为主,其他非主图例如法线、遮光、自发光图可以设定更小。
2、重复贴图的使⽤,⼤⾯积相同材质使⽤1-3种贴图交替重复覆盖,通过光影变化打破贴图的重复感。
3、贴图使用Bitmap贴图类型,尺寸主要为2的N次方。检查Inspector -> Advanced -> Non-Power of 2选项. 建议使用原始大小为2的幂次的贴图。大小非2的幂次的纹理资源将无法使用ETC1和PVRTC压缩格式。在导入时自动伸缩为2的幂次也可能会导致内存占用或者贴图质量问题。
4、少用透明贴图,能不⽤就不要⽤。透明贴图⾮常消耗GPU资源。并且带Alpha通道的贴图存储为tga或者png格式,在命名时必须加_al以区分。
5、贴图压缩,对贴图进⾏PVRT(iOS)或是ETC(Android)格式的压缩可以减少⼤量内存消耗。建议场景的材质可以⽤Substance材质系统转成.sbsar 格式材质。 Substance材质可以⼤⼤压缩贴图数据的⼤⼩但不损失贴图质量。
6、检查Mipmap标记,检查Inspector -> Advanced -> Generate Mip Maps选项,未压缩的纹理资源启用Mipmap标志会增加内存占用。
应用限制:未压缩的纹理资源应该禁用mipmap。类型为Sprite的纹理资源应当禁用mipmap。Mipmap 会增加游戏包体的大小和占用一定量的内存,但在游戏中Mipmap的渲染可以减少显存带宽,降低渲染压力,随着相机的推远贴图会随之切换成低像素的体贴,从而节省资源开支。过的Mipmap使用会对内存造成很大压力,因此建议只对大物件设置Mipmap。在这里插入图片描述
7、检查纹理读/写标记,检查Inspector -> Advanced -> Read/Write Enabled选项,默认必须要关闭,开启纹理资源的读/写标志会导致双倍的内存占用。在这里插入图片描述8、检查纹理资源的过滤模式,检查Inspector -> Filter Mode选项,纹理的过滤模式一般不建议使用Trilinear,会占用较高的计算资源。
在这里插入图片描述

三、动画层面

1、动画资源压缩方式 查看Inspector -> Animation Tab -> Anim. Compression选项,动画资源使用最佳压缩方式可以提高加载效率。 off:表示不采用压缩处理。keyfram Reduction:使用关键帧进行处理(旧版本unity:keyfram,reduction and compression表示关键帧减少和压缩)。Optimal:(新版本unity)自动选择一个最优的压缩方式。在这里插入图片描述
2、检查动画资源的Optimize Game Objects选项,查看Inspector -> Rig Tab -> Optimize Game Objects选项,动画资源应该勾选Optimize Game Objects选项来减少CPU消耗。
在这里插入图片描述

3、动画帧率、帧数控制,一般情况下每秒10帧,一个动画在1秒内完成。
4、动画模型的命名统一为基础模型名字➕@➕(动画前缀anim_)动画名字,做统一规范,同时会把该动画自动命名为@后面的名字。命名全部用英文或者拼音,并统一小写,不能出现中文。例如机器人待机动画(导出带动画骨骼的FBX文件提供给技术),C_RobotQ@anim_daiji。这样在Unity可以自动规范好anim clip 名称。在这里插入图片描述

四、声音层面:(音频通用设置)

Force To Mono:这个选项作用是强制单声道,很多声音为了追求质量会设置成双声道,导致声音在包体和内存中,占用的空间加倍,但是95%以上的声音,两个声道是完全一样的数据。因此对声音不是很敏感的项目建议勾选此项,来降低内存的占用。
Compression Format:不同的平台有不同的声音格式的支持,IOS对MP3有硬件支持,Android暂时没有硬件支持。建议IOS适合使用ADPCM和MP3格式,Android适合使用Vorbis格式。
Load Type:检查Inspector -> (Platform Tab) -> Load Type选项,音频加载类型,决定声音在内存中的存在形态:
Decompress On Load:当Audio Clip被加载时,解压声音数据,适用于小型音频文件(< 200kb)
Compressed In Memory:声音数据将以压缩的形式保存在内存当中,适用于中型音频文件(>= 200kb)
Streaming:从磁盘读取声音数据,适用于大型音频文件,例如背景音。注:例如Decompress On Load,要求文件必须小于200kb,因为内部内存管理的问题,如果是大于200kb的文件,那么也还是只会被分配到不足200kb的内存。
Bitrate:可以对音频文件本身进行压缩,降低文件的比特率(bitrate),前提音频品质不会被破坏太严重。
在这里插入图片描述

五、UI层面:

1、UI的隐藏可以使用将其移到Canvas外的方法,而不是SetActive(false)的方法来隐藏。
2、UI的批处理,如果UI元素会改变数值或是位置,会影响批处理,导致向GPU发送更多的drawcall。因此建议:将更新频率不同的UI放在不同的Canvas上。相同Canvas中的UI元素的Z值要相同,这样才不会打断批处理。相同Canvas中的UI元素要使用相同的材质和纹理,材质或着色器可以有动态变换(例如一些特效),这不会影响批处理。相同Canvas中的UI元素要使用相同裁剪矩阵。
3、Graphic Raycaster 该组件是用来处理输入事件,默认挂载在每个Canvas上。有时不能互动的对象仍是canvas中的一部分,并附带了该组件,所以当每次鼠标或触控点击时,系统就要遍历所有可能接受输入事件的UI元素,就会造成多次的 "点落在矩形中"的检查,来判断对象是否该作出反应。在UI很复杂的情况下,这个运算成本就会很高。因此建议确保只有可互动的Canvas才有该组件,节省CPU运行时间。
4、全屏UI的处理,游戏中可能会有些全屏UI(例如一些设置界面),会遮挡住场景物体或其他UI元素。然而它们即使被遮挡看不见,CPU和GPU还是会有消耗,因此建议:3D场景完全被遮挡的话,关闭渲染3D场景的摄像机。被遮蔽的UI,Disable这些Canvas,注意不是SetActive(false)。尽可能的降低帧率,因为这些UI一般不需要频繁刷新。

题外点:诚然在优化中,美术占比是很重要的,所以咱们从理论上再来理解一下美术制作流程。

次世代(Next Generation)与传统游戏相比,次世代游戏是把次世代游戏开发技术融入到现代游戏之中,通过增加模型的面数和贴图的数据量并使用次世代游戏引擎改善游戏的画面效果。标准表现在:模型达到高精度(高模) 、PBR流程的采用(真实法线+高光贴图)在真实光照下表现质感,属于新的游戏引擎技术。
PBR(Physically Based Rendering):PBR就是一种基于物理渲染,通过对真实世界物理现象进行逼近、模拟、再现,使3D对象在不同环境下都能展现出逼真的渲染质感,并通过材质的参数化将材质制作这一手工业流程转化成为标准化、流水化的工业流程。在这里插入图片描述
请添加图片描述
优秀的资源链接分享:
1、Unity 官方Profiler:https://docs.unity3d.com/Manual/ProfilerMemory.html
Unity URP:https://upr.unity.cn
2 、UWA相关:
2.1 使用UWA GOT优化Unity性能和内存:https://blog.uwa4d.com/archives/2029.html
2.2 可试用的产品介绍:https://blog.uwa4d.com/archives/UWA_PipelineV2-4.html
2.3 pipeline产品的介绍:https://blog.uwa4d.com/archives/UWA_Pipeline42.html
2.4 本地资源检测相关介绍:https://blog.uwa4d.com/archives/UWAGOTOL_Summary.html
2.5 GOT Online相关介绍:https://www.uwa4d.com/demo/projects.html
3、Unity 资源相关:
3.1 Unity 优化实践学习(二) 资源优化:https://blog.csdn.net/dengshunhao/article/details/82663719
3.2 Unity场景美术资源优化:https://blog.csdn.net/weixin_34203832/article/details/92379182
3.3 Unity整体性能优化篇 第(二)节-Unity资源优化:https://blog.csdn.net/chongzi_daima/article/details/101381290
4、Unity渲染技术:http://imgtec.eetrend.com/blog/2020/100050575.html
5、如何使用 Unity 和 Arm 分析工具解决移动端游戏性能问题(上篇):https://mp.weixin.qq.com/s/968NoWRjcV2rNYH51Mbfqg
6、全新Arm Mobile Studio for Unity软件包,增强移动端性能分析:https://developer.unity.cn/projects/60e2a5f9edbc2a04cfc5e341
7、Unity 性能优化经验整理:https://segmentfault.com/a/1190000019844821?utm_source=tag-newest
8、LuaProfiler:https://github.com/leinlin/Miku-LuaProfiler
9、Memory Profiler:https://docs.unity3d.com/Packages/com.unity.memoryprofiler@0.7/manual/index.html
https://www.bilibili.com/video/av334941622
10、垃圾回收:https://docs.microsoft.com/zh-cn/dotnet/standard/garbage-collection/fundamentals
11、Lua引用: https://github.com/jxhgzs/LuaMemorySnapshotDump
12、【Unity项目优化】之根据UPR资源检测报告进行项目资源优化总结:https://blog.csdn.net/qq_42437783/article/details/124275092

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

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

相关文章

Springboot实现定时任务

一、定时任务是什么&#xff1f; 定时执行任务&#xff0c;只有电脑不关机就可以在特定的时间去执行相应的代码&#xff0c;例如抢购脚本等 二、使用步骤 1.无需引入springboot自带 package com.ltx.blog_ltx;import org.springframework.boot.SpringApplication; import o…

java智慧工地 人脸识别终端,智慧工地解决方案源码

智慧工地即施工现场全面数字化过程&#xff0c;使用IOT、云、移动、大数据、AI等关键技术,进行生产要素、管理过程、建筑物实体的数据采集、数据治理&#xff0c;最终通过大数据和人工智能帮助项目实现精益管理。 智慧工地围绕工程现场人、机、料、法、环及施工过程中质量、安全…

并发控制工具类CountDownLatch、CyclicBarrier、Semaphore

并发控制工具类CountDownLatch、CyclicBarrier、Semaphore 1.CountDownLatch 可以使一个或多个线程等待其他线程各自执行完毕后再执行。 CountDownLatch 是多线程控制的一种工具&#xff0c;它被称为 门阀、 计数器或者闭锁。这个工具经常用来用来协调多个线程之间的同步&…

华为gre隧道全部跑静态路由

最终实现&#xff1a; 1、pc1能用nat上网ping能pc3 2、pc1能通过gre访问pc2 3、全部用静态路由做&#xff0c;没有用ospf&#xff0c;如果要用ospf&#xff0c;那么两边除了路由器上跑ospf&#xff0c;核心交换机也得用ospf r2配置&#xff1a; acl number 3000 rule 5 deny…

NVIDIA NCCL 源码学习(十二)- double binary tree

上节我们以ring allreduce为例看到了集合通信的过程&#xff0c;但是随着训练任务中使用的gpu个数的扩展&#xff0c;ring allreduce的延迟会线性增长&#xff0c;为了解决这个问题&#xff0c;NCCL引入了tree算法&#xff0c;即double binary tree。 double binary tree 朴素…

Qt下普通成员函数和静态成员函数作为回调函数的实现(替代信号与槽)

文章目录 前言一、使用信号与槽二、什么是回调函数三、使用普通成员函数作为回调函数四、使用静态成员函数作为回调函数五、示例完整代码总结 前言 在Qt中&#xff0c;使用信号与槽来实现不同对象之间的通信是非常方便的&#xff0c;这也是Qt框架中引以为傲的一项机制&#xf…

NVMe介绍

NVMe介绍 1 概述2 操作原理2.1 Queue基本原理2.2 Admin与I/O Queue2.3 Submission与Completion Queue2.4 Submission与Completion Queue对应关系 3 多路径I/O和命名空间共享3.1 1Port1Controller3.2 1Port2Controller3.3 2Port2Controller3.4 SR-IOV 本文属于《 NVMe协议基础系…

钓鱼与木马实践(仅供参考不可实践)

声明:内容仅供学习&#xff0c;请勿违法使用&#xff0c;违者后果自负 一.部署云服务器 购买一台云服务器,Windows&#xff08; 中文 &#xff09;版本即可 华为云官网&#xff1a;https://www.huaweicloud.com/ 登录后进入控制台购买完成后远程登录云服务器 二.部署WEB运行…

Linux内核编码规范

学习linux内核或者linux驱动的人应该先掌握内核编码规范&#xff0c;这样才能更好的驾驭linux内核、驱动。 下面就从这几个方面讲解一下linux内核编码规范。 注释风格、排版风格、头文件风格、变量定义、宏定义、函数 1 注释风格 1.1 注释的原则是有助于对程序的阅读和理解&…

一文了解提示工程(Prompt Engineering)

引言 在机器学习的世界里&#xff0c;有一句众所周知的话&#xff0c;“机器学习模型的好坏取决于您为其提供的训练数据。” 它指出了数据质量在您从这些算法中获得的结果中发挥的关键作用。 在使用生成式 AI 模型时&#xff0c;这一想法也很重要 - 无论它们生成文本、代码还…

第一次记录QPSK,BSPK,MPSK,QAM—MATLAB实现

最近有偶然的机会学习了一次QPSK防止以后忘记又得找资料&#xff0c;这里就详细的记录一下 基于 QPSK 的通信系统如图 1 所示&#xff0c;QPSK 调制是目前最常用的一种卫星数字和数 字集群信号调制方式&#xff0c;它具有较高的频谱利用率、较强的抗干扰性、在电路上实现也较为…

dotnet命令创建C#项目,VSCode打开

在命令行中创建项目并运行 1.首先安装.net 下载地址:.NET | 构建。测试。部署。 2.在 cmd 控制台输入 dotnet --vesion 检查版本号是否正常 3.我用git bash环境输入命令创建项目 // 创建文件夹 mkdir MyVSCode // 进入该文件夹 cd MyVSCode/ // 创建控制台项目 dotnet …