Unity骨骼动画的gpu instancing优化取代方案问题小结

2024-04-13 10:32

本文主要是介绍Unity骨骼动画的gpu instancing优化取代方案问题小结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主要参考文章为如下两篇:

1. https://www.cnblogs.com/murongxiaopifu/p/7250772.html

2. https://blog.csdn.net/zsy654321/article/details/80865060

关于RGBAHalf转RGB24,上面第二篇文章已经提到了.但是实际操作中还存在一些问题.比如filter mode的默认格式会导致在iOS平台上(我们用的是metal)顶点显示乱掉.因此filter mode需要修改为point(no filter).然后如果需要将Texture保存为图片文件,可以这样:

	void SaveTextureToFile(Texture2D texture, string fileName){string path = Application.dataPath + "/Test/" + fileName + ".png";//Debug.Log(path);var bytes = texture.EncodeToPNG();//or EncodeToEXR()File.WriteAllBytes(path, bytes);}

还有一个问题是,有时候RGB24就是不够用,也就是说我们想在Mobile平台用RGBAHalf,但是Unity会自动在Mobile平台将RGBAHalf转为RGBA32,所以需要手动转为exr格式,参考这篇文章:

https://www.sidefx.com/forum/topic/55791/?page=1#post-273779

或者就直接保存为asset好了.

此外,tex2Dlod也不需要mipmap(用tex2Dlod是因为在vertex shader当中无法用tex2D,详细解释看这里https://forum.unity.com/threads/how-to-sample-a-texture-in-vertex-shader.513816/),所以关闭png文件的mipmap,还可以节省约33%的内存.

最后,需要注意如果项目总体使用了LinearSpace,需要取消勾选材质的sRGB选项,避免自动进行Gamma矫正而得到错误的结果.

P.S. 关于如何加入随机播放,简单说下,只要在shader里加一个offset并暴露出来,然后在C#里new一个MaterialPropertyBlock,用SetPropertyBlock传一个随机值给这个offset就好了.想要随机播放的同时保持可batching,可以看之前我的总结https://blog.csdn.net/tlrainty/article/details/81127234

后续补充:

经过进一步测试,决定采用这篇文章 https://blog.csdn.net/yxriyin/article/details/83018985 中提到的烘焙骨骼来代替烘焙顶点,主要原因是烘焙顶点有以下两个关键缺点:

1.顶点数直接决定了贴图大小,因此顶点数很受限制,一般要约束在512以下.而且即使约束了顶点数也比烘焙骨骼生成的贴图大很多.

2.对于多个SkinnedMeshRenderer共享一套骨骼,尤其其中一个SMR的关节是另一个SMR的子关节的情况(也就是被另一个SMR的关节带动),烘焙顶点是无解的.因为烘焙出来后各SMR之间就相对独立了,没有了骨骼信息.

当然,骨骼贴图的话shader中每顶点要采样三次,而且还要多一步矩阵乘法,会有一定性能消耗.但目前经过测试,对于我们项目来说这个消耗不是那么明显,结果尚可接受.

 

这篇关于Unity骨骼动画的gpu instancing优化取代方案问题小结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/899893

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

高效+灵活,万博智云全球发布AWS无代理跨云容灾方案!

摘要 近日,万博智云推出了基于AWS的无代理跨云容灾解决方案,并与拉丁美洲,中东,亚洲的合作伙伴面向全球开展了联合发布。这一方案以AWS应用环境为基础,将HyperBDR平台的高效、灵活和成本效益优势与无代理功能相结合,为全球企业带来实现了更便捷、经济的数据保护。 一、全球联合发布 9月2日,万博智云CEO Michael Wong在线上平台发布AWS无代理跨云容灾解决方案的阐述视频,介绍了

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监