-
Notifications
You must be signed in to change notification settings - Fork 513
ModelBone
This class is part of the Model hierarchy. The purpose of this structure is to define a hierarchy of transformation matrices used for rigid-body animation, skinning animation, or as metadata for locations associated with a model for runtime insertion of dynamic lights, particle effects, etc.
The use of ModelBone is optional and the Model::bones
array an therefore be empty.
#include <Model.h>
The ModelBone array bones is typically created by a Model loader along with the ModelMesh instances that contain the submeshes. By default the loader ignores any frames (SDKMESH) or bones (CMO) found in the file. Providing the ModelLoader_IncludeBones
flag will result in any bones present in the model file being loaded.
ModelBone::Collection is an alias for std::vector<ModelBone>
.
ModelBone::TransformArray is an alias for std::unique_ptr<XMMATRIX[], aligned_deleter>
.
ModelBone::TransformArray instances are created using the static method ModelBone::MakeArray
. This memory is always allocated using _aligned_malloc
with 16-byte alignment to meet the requirements for SIMD.
auto bones = ModelBone::MakeArray(model->bones.size());
A ModelBone instance contains a name (a wide-character string) typically used for matching up bones with animation keys.
Each bone contains three pointers:
-
parentIndex is the index of the parent of this bone (or
ModelBone::c_Invalid
if it has no parent). -
childIndex is the index of the child of this bone (or
ModelBone::c_Invalid
if it has no children). -
siblingIndex is the index of the next sibling of this bone (or
ModelBone::c_Invalid
if it has no siblings).
These pointers are used to form a tree hierarchy. The 0th bone in a Model is the root and should have a parentIndex of ModelBone::c_Invalid
.
Note that bones must form an acyclic graph.
The XNA Game Studio ModelBone design relied on the fact that the Content Pipeline always sorted the bone array in a particular way. This uses a more complex tree graph structure to support SDKMESH and CMO which may not meet these sorting requirements.
There is no explicit root bone in a Model in DirectX Tool Kit. By convention, the 0th bone is the root.
All content and source code for this package are subject to the terms of the MIT License.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.
- Universal Windows Platform apps
- Windows desktop apps
- Windows 11
- Windows 10
- Windows 8.1
- Xbox One
- x86
- x64
- ARM64
- Visual Studio 2022
- Visual Studio 2019 (16.11)
- clang/LLVM v12 - v18
- MinGW 12.2, 13.2
- CMake 3.20