UE4角色Location远距离时动画抖动问题(float精度不够)解决方案

正题:关于UE4引擎当角色Location超过9999.999后,角色动画更新抖动问题的解决思路。
前提:
1.UE4引擎中距离单位是厘米(cm),也就说我们制作好1.8米的角色在UE4中为180个虚幻单位。这样做个人愚见是为了提高浮点值(float)后面的精度。
2.UE4中Location的单位是使用的FVector,FVector是由3个float组成X,Y,Z。在DX11渲染模式下使用SSE指令集进行CPU加速计算优化,使用的是__m128(float4)由4个float浮点值组成。见下图:


3.插槽Socket的更新是在CPU直接通过骨骼(bone)的矩阵直接去乘Component矩阵或者是Actor矩阵或者是Word矩阵得到的结果,所以基本不存在GPU更新CPU更新的问题。
发现问题:
角色在大世界无缝拼接的地图上移动时或者不定位置进行运行时,相机离角色模型或者插槽(Socket)绑定的模型(Mesh)很近时会发现角色或者绑定在插槽上的模型开始抖动,并且在多次测试中发现抖动幅度并不一致。
透过现象猜本质:(推测)
1. 相机离角色部位或者插槽模型很近时遮蔽大部分骨骼,occ会踢出或降低骨骼在GPU更新频率。
2. 当角色远离原点时或者相机只看到绑定点时,骨骼或者动画会LOD降低末端骨骼更新频率或者降低计算精度。
3.当角色远离原点时3个float组成的FVector精度不够。(推测时认为可能性极低,引擎应该考虑过精度问题,并且当时角色距离原点位置目测不远)
4. 写代码时获取插槽位置方式不正确,或是Mesh绑定方式不正确。(推测时认为可能性极大... 找问题先从自身出发...)
测试:用~控制台-命令行DEBUGSHOWANIMATION显示骨骼和动画信息,并且更好绑定方式和获取插槽坐标,并用多种输出方式和输出断点调试输出位置信息。
最终经过多次测试和代码调试发现当角色Location超过9999.999后因为float只能保证7位有效数据而导致精度出现问题从而骨骼更新时出现抖动问题,并且小数点前面的位数越多精度越底。
解决思路:
1. 修改float单精度浮点值为双精度浮点值。 2. 修改本地坐标或者基础虚幻距离单位。
解决方案:(支持RPC)
使用WorldOrigin世界原点偏移来解决float精度不够问题。UnrealEngine4.12版本后加入并完善了大世界无缝地图模块(WorldTravel)和编辑功能,在Levels编辑器中可以加入子关卡作为流关卡加载(LevelStraming)。可以在主关卡的世界设置里(WorldSeting)中设置启用WorldComponent并且勾选世界原点偏移WorldOrigin。
1. 在配置文件中添加 p.EnableMultiplayerWorldOriginRebasing=true
2. 当角色将要超过9999.99之前判断当前角色是否超过自己业务中设定最大偏移值。如果超过请使用voidUGameplayStatics::GetWorldOriginLocation获得当前原点坐标的世界位置(转换前的真实位置:比如之前把8800,0,0转换成了0,0,0)加上角色的当前位置再使用UGameplayStatics::SetWorldOriginLocation来设置角色的当前位置为新的世界坐标的原点,这样角色在更新动画时或者进行其他计算时会按照当前设置的位置作为原点(0,0,0)点更新或计算从而减小误差。
3. 注意这两个API的入参和返回值都是FIntVector转换时不要丢掉精度。当客户端SetWorldOriginLocation时Levels会遍历所有关卡中的Level.Actor.Component进行WorldOffset修改会比较耗时(尤其是关卡中物体很多时请诸君慎用)最好是做一个坐标管理器系统(CoordSystem)搭配多种策略来进行使用,减少使用频次。例如:当需要近距离观察角色或者插槽上挂的Mesh时更新,或者FPS游戏拿出可以开启瞄准或者开镜武器时,角色位置每当超过8888时等等。
4.世界原点偏移(WorldOrigin)在RPC模式下只会修改客户端位置,在移动同步(Movement)根骨骼位移(RootMotion)物理计算模拟(PhysicsSimulate)时在同步时会把角色当前位置和世界原点偏移位置加起来一起发到服务器。服务器接收的真实位置而不是修改世界原点后角色位置。

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

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

相关文章

android Handler的使用(一)

Handler的使用(一) Handler基本概念: Handler主要用于异步消息的处理:当发出一个消息之后,首先进入一个消息队列,发送消息的函数即刻返回,而另外一个部分逐个的在消息队列中将消息取出,然后对消息进行出来…

php和python的多线程,Python多线程以及线程锁简单理解(代码)

本篇文章给大家带来的内容是关于Python多线程以及线程锁简单理解(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。多线程threading 模块创建线程创建自己的线程类线程通信线程同步互斥方法线程锁需要了解!&a…

现实地形导入UE4全流程

制作地形方法很多,今天给大家分享一种原创野套路。此方法特点是将现实中的地形于UE4中呈现,而不是手动绘制地形。首先从地理空间数据云获得指定区域的地理数据,然后使用GlobalMapper更准确选出区域并把数据转换成WorldMachine可识别的格式&am…

php对象存储hadoop存储,三个理由告诉你对象存储替换HDFS还不错

Hadoop使企业能够对庞大的非结构化数据集进行大规模分析处理。这个数据集可以包含数以百万计,甚至数十亿个需要读取的文件。为了降低成本并提高数据处理性能,数据和应用程序应该存在于相同的物理硬件上。这样做使数据无需移动,就地处理&#…

Web请求中同步与异步的区别

普通的B/S模式就是同步,而AJAX技术就是异步,当然XMLHttpReques有同步的选项。 同步:提交请求->等待服务器处理->处理完毕返回。这个期间客户端浏览器不能干任何事。 异步: 请求通过事件触发->服务器处理(这是浏览器仍然可…

大地形pawn抖动问题

在pawn的event tick里调用下面函数即可

php蓝牙连接不上,蓝牙音响连接不上手机怎么办 两种方法轻松解决连接问题

我们听歌一般用耳机和音响。现在蓝牙音频越来越普及,但毕竟是无线产品。信号不时中断或不连接是正常的。蓝牙音频连不上手机真的很头疼。出现这种情况的原因是什么,如何解决?为什么蓝牙音频不能连接到手机1.蓝牙音频没有进入匹配状态&#xf…

Bootstrap页面布局16 - BS导航菜单和其响应式布局以及导航中的下拉菜单

代码&#xff1a; <div classcontainer-fluid><h2 classpage-header>导航</h2><!--    .navrbar navbar-fixed-top:导航固定显示在顶部&#xff0c;对应的navbar-fixed-bottom:导航固定显示在页面底部    .brand:提示文字或者主题    .active…

HMI使用自定义控件流程

1.定义控件ID号&#xff0c;以FO_COMP_CUSTOM为基数#define SCENEENTITY_SIMULATOR_SHAPEFO_COMP_CUSTOM 2102.编写控件类&#xff0c;并继承于CFOBitmapShape 具体实现可以在程序中找例子&#xff0c;重新OnDraw3d这个虚函数来实现控件的绘制3. 在MainFrm.cpp中&#xff0c;在…

nginx 怎么重新编译安装mysql,centos 下 编译安装 nginx + mysql + php 服务

centos 下编译安装nginx mysql php 服务1、安装nginx1.1、安装依赖包yum install wget make gcc gcc-c pcre-devel openssl-devel -y yum install ncurses-devel libtool zilib-devel -y1.2、创建www用户useradd www -s /sbin/nologin -M1.3、创建目录mkdir -p /var/log/ngin…

hdu 1874(Dijkstra + Floyd)

链接&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid1874 畅通工程续 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 27692 Accepted Submission(s): 10019 Problem Description某省自从实行了很多年…

php原生session,利用Memcached在php下实现session机制 替换PHP的原生session支持

方法文件session实现文件:memcachedsession.php实现原理(也是PHP内部session的实现原理)&#xff1a;1.先判断客户端有没有sessionid&#xff0c;a.没有就添加一个sessionid给客户端&#xff0c;通常是32位hash码&#xff0c;同时初始化一个数组做session容器b.如果客户端有ses…

Web 开发中很实用的10个效果【附源码下载】

在工作中&#xff0c;我们可能会用到各种交互效果。而这些效果在平常翻看文章的时候碰到很多&#xff0c;但是一时半会又想不起来在哪&#xff0c;所以养成知识整理的习惯是很有必要的。这篇文章给大家推荐10个在 Web 开发中很有用的效果&#xff0c;记得收藏&#xff01; 超炫…

深入分析MFC文档视图结构(项目实践)

文档视图结构&#xff08;Document/View Architecture&#xff09;是MFC的精髓&#xff0c;也是Observer模式的具体实现框架之一&#xff0c;Document/View Architecture通过将数据和其表示分开&#xff0c;提供了很好的数据层次和表现层次的解耦。然而&#xff0c;虽然我们使用…

蓝图中实现人物移动2

从Pawn继承一个蓝图类并编写下面代码&#xff0c;并添加摄像机组件 1. 实现前后移动2. 实现左右移动3. 实现鼠标移动方向4. 实现鼠标俯仰

php 提取前一百个字,如何在PHP中提取字符串的前100個字符?

I am looking for a way to pull the first 100 characters from a string variable to put in another variable for printing.我正在尋找一種方法&#xff0c;從字符串變量中提取前100個字符&#xff0c;並將其放入另一個變量中進行打印。Is there a function that can do th…

实现两个pawn的切换

在playercontroller里面编写下面代码并把两个pawn放置到场景中

zoj2008 最短路

题意&#xff1a;给你n个点的有向图&#xff0c;从1点到其他所有点又从其他点回到1点的最短路。 思路&#xff1a;可以求一次从1点出发的最短路&#xff0c;再反向建图&#xff0c;再求一次从1出发的最短路&#xff0c;把两次的结果加起来就是题目所求。由于边比较多&#xff0…

steam程序员php玩的游戏,Steam:又一款烧脑的编程游戏上线,宅男回家了也要开心加班!...

原标题&#xff1a;Steam&#xff1a;又一款烧脑的编程游戏上线&#xff0c;宅男回家了也要开心加班&#xff01;要是小伙伴们喜欢什么解谜、编程类游戏&#xff0c;相信Steam上的《程序员升职记》应该都是绿了的游戏&#xff0c;这款给宅男们设计智力游戏能让你享受到从底层到…

模式(一)javascript设计模式

模式有三种&#xff1a;Architectural Pattern、Design Pattern、Coding Pattern&#xff0c;即&#xff1a;框架模式、设计模式、编程模式。本文主要讲解javascript中的设计模式&#xff0c;好的设计模式能够提高代码的重用性&#xff0c;可读性&#xff0c;使代码更容易的维护…