gpt4 book ai didi

c++ - 使用 FBX 的骨骼动画

转载 作者:行者123 更新时间:2023-11-30 04:28:12 24 4
gpt4 key购买 nike

我正在为我们的小型游戏引擎编写一个 fbx 转换器。我坚持使用动画渲染模型。每个时间戳的矩阵看起来都不错,当我只渲染骨骼时,它看起来也像原始动画。我做了一些快照来显示我的问题。我只是不知道出了什么问题。也许有人可以给我提示 :)

我用于测试的文件是来自 FBX-SDK 的 humanoid.fbx。

着色器应该没问题:

VS_OUT output = (VS_OUT)0;

float4x4 skinTransform = 0;
skinTransform += MatrixPallette[input.BoneIndices.x] * input.Weights.x;
skinTransform += MatrixPallette[input.BoneIndices.y] * input.Weights.y;
skinTransform += MatrixPallette[input.BoneIndices.z] * input.Weights.z;
skinTransform += MatrixPallette[input.BoneIndices.w] * input.Weights.w;
//skinTransform = mul(BindShape, skinTransform);

//Transform Position
float4 worldPosition = mul(input.Position, skinTransform);
float4 viewPosition = mul(worldPosition, matView);
output.Position = mul(viewPosition, matProj);

这是图片。 (右 -> 原始) http://www.pic-upload.de/view-13949399/Unbenannt.png.html

最佳答案

与其计算顶点的“皮肤变换”,我建议使用提供的变换计算变换后的顶点,然后使用权重获得组合位置。对两个矩阵进行插值确实不是一个好主意。

float4 worldPosition = 0;
worldPosition += mul(input.Position, MatrixPallette[input.boneIndicies.x]) * input.Weights.x;
worldPosition += mul(input.Position, MatrixPallette[input.boneIndicies.y]) * input.Weights.y;
worldPosition += mul(input.Position, MatrixPallette[input.boneIndicies.z]) * input.Weights.z;
worldPosition += mul(input.Position, MatrixPallette[input.boneIndicies.w]) * input.Weights.w;

但是,当您看到这种变形的物体时,通常意味着您忘记了将矩阵调色板乘以“反向骨骼变换”。反向骨骼变换是骨骼在“皮肤游行”姿势中的变换矩阵(即,对象已被装配的原始姿势)。要计算蒙皮对象的正确位置,您应该在矩阵调色板中存储组合变换 = inverse(skinParadeTransform)*currentTransform。 Current transform 是骨骼在当前动画层次结构中的变换,skinParadeTransform 是“skin parade”模式下的原始骨骼变换。 inverse 是矩阵求逆(是的,你必须这样做)。

关于c++ - 使用 FBX 的骨骼动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10353110/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com