头图

关于Gfx.WaitForPresent的耗时问题

1)关于Gfx.WaitForPresent的耗时问题
​2)关于Spine Shader冗余问题
3)Unity添加了ARR插件后导出Android错误
4)对压缩格式的纹理调用GetPixels方法的疑问


这是第284篇UWA技术知识分享的推送。今天我们继续为大家精选了若干和开发、优化相关的问题,建议阅读时间10分钟,认真读完必有收获。

UWA 问答社区:answer.uwa4d.com
UWA QQ群2:793972859(原群已满员)

SpriteAtlas

Q:Profiler里看手机上的CPU、GPU耗时,发现有时候CPU上Gfx.WaitForPresentOnGfxThread的时间是GPU耗时的几倍。可以看出GPU耗时只有9毫秒,但是CPU等待了29毫秒,是GPU耗时的3倍多,请问这是什么原因导致的?

A:一般WaitForPresent出现一段耗时表示CPU在等待GPU渲染,一般是GPU压力大,渲染线程会有一段Gfx.PresentFrame(Vulkan的话子堆栈还有GfxDeviceVK.Present),最常见的情况如下:

若同时CPU开销也比较高,这段等待也会被代码耗时所覆盖,如下(主线程Sleep 4ms):

从题主的截图来看是开启了Profiler的GPU Mode,该模式对GL接口打点会性能更低,渲染线程可以看到GPUProfiler.Begin/EndQueries打点的耗时,体现在主线程就是Wait的耗时高,如下(建议关闭GPU Mode再进行测试):

对于题主描述的在主线程WaitForPresent存在一定的开销的情况下,渲染线程几乎没有统计到任何开销情况,不知道大家有没有遇到过类似的问题。

感谢羽飞@UWA问答社区提供了回答

AssetBundle

Q:如下图所示,做一个预制体放到AssetBundle包中,预制体只包含一个Spine对象,但每次打AssetBundle包都会把Spine的5个Shader打包到AssetBundle包里面,这种AssetBundle极为冗余。

并且如下图所示,Spine的五个Shader已经添加到Always Included Shaders中。请问是否有什么方法可以解决Spine AssetBundle包中的Shader冗余?

A1:把Spine的资源也打包,反正就几个Shader和材质球。

感谢1 9 7 3-311135@UWA问答社区提供了回答

A2:像Spine这种第三方插件的Shader,不属于Unity内置的Shader,放入Always Included Shaders设置项中是没有任何用处的。需要自己对它们主动打包进AssetBundle中,否则其他AssetBundle中用到了它们的引用,就会被动将其拉进AssetBundle中。主动打包后,其他用到这个Spine Shader的AssetBundle只是会依赖Spine Shader打的AssetBundle。

感谢Xuan@UWA问答社区提供了回答

A3:像这样的需求,需要自己在打包策略上做处理,可以把资源引用都关联,自己单独处理每个包的依赖,自己在Shader列表里加入一些黑名单,或者在打包依赖里自己处理,这就看自己想怎么设计关联与依赖了。

感谢廖武兴@UWA问答社区提供了回答

Android

Q:Unity升级到版本2021.2.8。之前可以直接把res目录放在Plugins/Android/res,但是现在好像改了,详情可以参考以下网址:https://docs.unity3d.com/2022...

否则错误提示:
OBSOLETE - Providing Android resources in Assets/Plugins/Android/res is deprecated...

现在我从Android Studio中生成AAR导入到Unity中打包,还是报错:

A:之前用Unity 2019的AAR包中我都把Androidmainfest.xml删除了,但是升级到了Untiy 2021.2.8版本就出问题了,解决方案就是保留AAR中的AndroidMainfest.xml,自己手动合并。

感谢题主zerolj@UWA问答社区提供了回答

Texture

Q:看官方文档,如果纹理设置开关R/W Enabled启用时,可以通过Texture.GetPixels/SetPixels读写纹理数据。

请问,压缩格式的纹理(比如ETC)在内存中的形式应该是未解压的,那么在调用GetPixels时会在CPU端解压吗?

A:在Unity 2019.4.10f1上做了一个测试,代码如下:

结果如下:

左边是ETC2 8Bits,右边是代码生成的,2是原图,n/a是代码生成的,从手机截图上看,肉眼似乎分辨不出区别。

又做了一个额外的测试,让不压缩的图GetPixels,和ETC2的图GetPixels的值作差。

结果如下图,得到的是一个全黑的图,左边是ETC2格式的图,右边是生成的图。

由上面的测试可知,GetPixels得到的值是和RGBA32格式的数值是一致的。猜测底层在操作GetPixels时,应该做了解压。

感谢Xuan@UWA问答社区提供了回答

封面图来源于网络


今天的分享就到这里。当然,生有涯而知无涯。在漫漫的开发周期中,您看到的这些问题也许都只是冰山一角,我们早已在UWA问答网站上准备了更多的技术话题等你一起来探索和分享。欢迎热爱进步的你加入,也许你的方法恰能解别人的燃眉之急;而他山之“石”,也能攻你之“玉”。

官网:www.uwa4d.com
官方技术博客:blog.uwa4d.com
官方问答社区:answer.uwa4d.com
UWA学堂:edu.uwa4d.com
官方技术QQ群:793972859(原群已满员)

UWA官网:[链接]

27 声望
12 粉丝
0 条评论
推荐阅读
MeshRenderer如何使用GPU Instancing的材质球正常合批
1)MeshRenderer如何使用GPU Instancing的材质球正常合批​2)关于AssetBundle加密,如何重新实现LoadFromFile接口3)移动端开放世界类型游戏中选择动态阴影技术以及优化方案组合4)Unity导出Gradle工程,如何防止...

侑虎科技阅读 44

封面图
程序员英语学习指南
动机为什么程序员要学习英语?工作:我们每天接触的代码都是英文的、包括很多技术文档也是英文的学习:最新最前沿的技术最开始都是只有English版本就业:学好英语让你的就业范围扩大到全球,而不只限于国内目标读...

九旬6阅读 656

安卓逆向之破解某成人APP播放次数限制
某成人水果APP非VIP用户存在播放次数限制,每天只能播放3次。超过3次需要购买VIP。 由于过于贫穷,于是抽空,对其安卓APP进行了逆向分析,最终成功破解了其播放次数限制。

悖论3阅读 1.3k评论 3

封面图
这一次,解决Flutter Dialog的各种痛点!
4.0版本做了重大调整,迁移请参照: SmartDialog 3.x 迁移 4.0本文内容已更新,文中内容及其代码皆为4.0用法前言Q:你一生中闻过最臭的东西,是什么?A:我那早已腐烂的梦。兄弟萌!!!我又来了!这次,我能自信...

小呆呆6661阅读 3.5k

封面图
uni-app中安卓包检查更新、新版本下载、下载进度条显示功能实现
如果想要做一个app的话,可以有很多种选择方案,uni-app是其中的一个性价比高一些(坑多一些)的方案。本文记录一下,uni-app打安卓包以后,需要检查并下载更新,且显示进度条的功能。

水冗水孚2阅读 756

网易云音乐开源全链路埋点方案-曙光埋点(dawn)
网易云音乐开源了曙光埋点 dawn,一个跨多端的全链路埋点解决方案,旨在构造一个完美的数据理想国。曙光埋点创造性的提出了埋点虚拟树(VTree),并在此基础上实现了诸多能力,解决大前端侧埋点困难、精度差、不...

云音乐技术团队2阅读 340

封面图
Flutter 让你的Dialog脱胎换骨吧!(Attach,Dialog,Loading,Toast)
4.0版本做了重大调整,迁移请参照: SmartDialog 3.x 迁移 4.0本文内容已更新,文中内容及其代码皆为4.0用法前言Q:你一生中闻过最臭的东西,是什么?A:我那早已腐烂的梦。兄弟萌!!!我又来了!这次,我能自信...

小呆呆6662阅读 2.3k

封面图

UWA官网:[链接]

27 声望
12 粉丝
宣传栏