FBX2glTF/sdk/Darwin/2019.2/include/fbxsdk/scene/constraint/fbxcontrolset.h

371 lines
13 KiB
C++

/****************************************************************************************
Copyright (C) 2015 Autodesk, Inc.
All rights reserved.
Use of this software is subject to the terms of the Autodesk license agreement
provided at the time of installation or download, or which otherwise accompanies
this software in either electronic or hard copy form.
****************************************************************************************/
//! \file fbxcontrolset.h
#ifndef _FBXSDK_SCENE_CONSTRAINT_CONTROL_SET_H_
#define _FBXSDK_SCENE_CONSTRAINT_CONTROL_SET_H_
#include <fbxsdk/fbxsdk_def.h>
#include <fbxsdk/scene/constraint/fbxcharacter.h>
#include <fbxsdk/fbxsdk_nsbegin.h>
class FbxControlSetPlug;
/** \class FbxControlSetLink
*
* \brief This class represents a link between a given character's FK node and the associated node in the character hierarchy.
*
*/
class FBXSDK_DLL FbxControlSetLink
{
public:
//! Default constructor.
FbxControlSetLink();
/** Copy constructor.
* \param pControlSetLink Given object.
*/
FbxControlSetLink(const FbxControlSetLink& pControlSetLink);
/** Assignment operator.
* \param pControlSetLink Another FbxControlSetLink object assigned to this one.
*/
FbxControlSetLink& operator=(const FbxControlSetLink& pControlSetLink);
/** Reset to default values.
*
* Member mNode is set to \c NULL and member mTemplateName is cleared.
*/
void Reset();
//! The character's node in a hierarchy linked to this control set link.
FbxNode* mNode;
//! A template name is a naming convention that is used to automatically map
//! the nodes of other skeletons that use the same naming convention for automatic characterization.
FbxString mTemplateName;
};
/**
* An effector wraps a character node (FbxNode) used to animate its control rig (FbxControlSet) via inverse kinematics.
*/
class FBXSDK_DLL FbxEffector
{
public:
enum ESetId
{
eDefaultSet,
eAux1Set,
eAux2Set,
eAux3Set,
eAux4Set,
eAux5Set,
eAux6Set,
eAux7Set,
eAux8Set,
eAux9Set,
eAux10Set,
eAux11Set,
eAux12Set,
eAux13Set,
eAux14Set,
eSetIdCount
};
enum ENodeId
{
eHips,
eLeftAnkle,
eRightAnkle,
eLeftWrist,
eRightWrist,
eLeftKnee,
eRightKnee,
eLeftElbow,
eRightElbow,
eChestOrigin,
eChestEnd,
eLeftFoot,
eRightFoot,
eLeftShoulder,
eRightShoulder,
eHead,
eLeftHip,
eRightHip,
eLeftHand,
eRightHand,
eLeftHandThumb,
eLeftHandIndex,
eLeftHandMiddle,
eLeftHandRing,
eLeftHandPinky,
eLeftHandExtraFinger,
eRightHandThumb,
eRightHandIndex,
eRightHandMiddle,
eRightHandRing,
eRightHandPinky,
eRightHandExtraFinger,
eLeftFootThumb,
eLeftFootIndex,
eLeftFootMiddle,
eLeftFootRing,
eLeftFootPinky,
eLeftFootExtraFinger,
eRightFootThumb,
eRightFootIndex,
eRightFootMiddle,
eRightFootRing,
eRightFootPinky,
eRightFootExtraFinger,
eNodeIdCount,
eNodeIdInvalid=-1
};
//! Default constructor with uninitialized character node.
FbxEffector();
/** Assignment operator.
* \param pEffector Another FbxEffector assigned to this one.
*/
FbxEffector& operator=(const FbxEffector& pEffector);
/** Reset to default values.
* - mNode is set to NULL.
* - mShow is set to true.
*/
void Reset();
//! The character's node in a hierarchy linked to this effector.
FbxNode* mNode;
//! \c true if the effector is visible, \c false if hidden
bool mShow;
/*****************************************************************************************************************************
** WARNING! Anything beyond these lines is for internal use, may not be documented and is subject to change without notice! **
*****************************************************************************************************************************/
#ifndef DOXYGEN_SHOULD_SKIP_THIS
//These members are for backward compatibility and should not be used.
//These properties are now published through class FbxControlSetPlug.
bool mTActive;
bool mRActive;
bool mCandidateTActive;
bool mCandidateRActive;
#endif /* !DOXYGEN_SHOULD_SKIP_THIS *****************************************************************************************/
};
/** \class FbxControlSet
*
* This class contains all methods to either set-up an exported control rig or query information on an imported control rig.
* A Control rig is a character manipulation tool that lets you change the position and orientation
* of a character to create or alter animation.
*
* This class also contains some methods to manipulate the FbxEffector and FbxControlSetLink.
*
* The FbxControlSet class contains FK rig (Forward Kinematics) and IK rig (Inverse Kinematics) animation. The FK rig is represented
* by a list of nodes while the IK rig is represented by a list of effectors.
*
* You can access the FK rig with the FbxControlSetLink class, using the functions FbxControlSet::SetControlSetLink() and FbxControlSet::GetControlSetLink().
*
* You can access the IK rig with the FbxEffector class, using the functions FbxControlSet::SetEffector() and FbxControlSet::GetEffector().
*
* \see FbxEffector, FbxControlSetLink
*/
class FBXSDK_DLL FbxControlSet
{
public:
/** Reset to default values.
* Reset all effector and control set links.
*/
void Reset();
/** \enum EType Control rig type.
* - \e eNone No Control rig.
* - \e eFkIk Both an FK rig and IK rig.
* - \e eIkOnly Only an IK rig.
*/
enum EType
{
eNone,
eFkIk,
eIkOnly
};
/** Set type as given.
* \param pType The given type.
*/
void SetType(EType pType);
/** Get type.
* \return The gotten type.
*/
EType GetType() const;
/** Set use axis flag as given.
* \param pUseAxis The given use axis flag.
*/
void SetUseAxis(bool pUseAxis);
/** Get use axis flag.
* \return The gotten use axis flag.
*/
bool GetUseAxis() const;
/** Set lock transform flag as given.
* \param pLockTransform The given lock transform flag.
*/
void SetLockTransform(bool pLockTransform);
/** Get lock transform flag.
* \return The gotten lock transform flag.
*/
bool GetLockTransform()const;
/** Set lock 3D pick flag as given.
* \param pLock3DPick The given lock 3D pick flag.
*/
void SetLock3DPick(bool pLock3DPick);
/** Get lock 3D pick flag.
* \return The gotten lock 3D pick flag.
*/
bool GetLock3DPick() const;
/** Set a control set link for a character node ID.
* \param pCharacterNodeId Character node ID.
* \param pControlSetLink Control set link to be associated with the Character node ID.
* \return \c true if successful, \c false otherwise.
* \remarks You should avoid setting a control set link for
* eCharacterLeftFloor, eCharacterRightFloor, eCharacterLeftHandFloor, eCharacterRightHandFloor,
* eCharacterProps0, eCharacterProps1, eCharacterProps2, eCharacterProps3 or eCharacterProps4.
* None of these nodes are part of a control set.
*/
bool SetControlSetLink(FbxCharacter::ENodeId pCharacterNodeId, const FbxControlSetLink& pControlSetLink);
/** Get the control set link associated with a character node ID.
* \param pCharacterNodeId Requested character node ID.
* \param pControlSetLink Optional pointer that returns the control set link if the function succeeds.
* \return \c true if successful, \c false otherwise.
* \remarks You should avoid getting a control set link for
* eCharacterLeftFloor, eCharacterRightFloor, eCharacterLeftHandFloor, eCharacterRightHandFloor,
* eCharacterProps0, eCharacterProps1, eCharacterProps2, eCharacterProps3 or eCharacterProps4.
* None of these nodes are part of a control set.
*/
bool GetControlSetLink(FbxCharacter::ENodeId pCharacterNodeId, FbxControlSetLink* pControlSetLink = NULL) const;
/** Set an effector node for an effector node ID.
* \param pEffectorNodeId Effector node ID.
* \param pEffector Effector to be associated with the effector node ID.
* \return \c true if successful, \c false otherwise.
*/
bool SetEffector(FbxEffector::ENodeId pEffectorNodeId, FbxEffector pEffector);
/** Get the effector associated with an effector node ID.
* \param pEffectorNodeId ID of requested effector node.
* \param pEffector Optional pointer that returns the effector if the function succeeds.
* \return \c true if successful, \c false otherwise.
*/
bool GetEffector(FbxEffector::ENodeId pEffectorNodeId, FbxEffector* pEffector = NULL);
/** Set an auxiliary effector node for an effector node ID.
* \param pEffectorNodeId Effector node ID.
* \param pNode Auxiliary effector node to be associated with the effector node ID.
* \param pEffectorSetId Effector set ID. Set to FbxEffector::eAux1Set by default.
* \return \c true if successful, \c false otherwise.
*/
bool SetEffectorAux(FbxEffector::ENodeId pEffectorNodeId, FbxNode* pNode, FbxEffector::ESetId pEffectorSetId=FbxEffector::eAux1Set);
/** Get the auxiliary effector associated with an effector node ID.
* \param pEffectorNodeId ID of requested auxiliary effector node.
* \param pNode Optional pointer that returns the auxiliary effector node if the function succeeds.
* \param pEffectorSetId Effector set ID. Set to FbxEffector::eAux1Set by default.
* \return \c true if successful, \c false otherwise.
*/
bool GetEffectorAux(FbxEffector::ENodeId pEffectorNodeId, FbxNode** pNode=NULL, FbxEffector::ESetId pEffectorSetId=FbxEffector::eAux1Set) const;
/** Get the name associated with an effector node ID.
* \param pEffectorNodeId Effector node ID.
* \return Name associated with the effector node ID.
*/
static char* GetEffectorNodeName(FbxEffector::ENodeId pEffectorNodeId);
/** Get ID associated with an effector node name.
* \param pEffectorNodeName Effector node name.
* \return Effector node ID associated with the given effector node name, or FbxEffector::eNodeIdInvalid (-1) if
* no effector node with pEffectorNodeName exists.
*/
static FbxEffector::ENodeId GetEffectorNodeId(const char* pEffectorNodeName);
/*****************************************************************************************************************************
** WARNING! Anything beyond these lines is for internal use, may not be documented and is subject to change without notice! **
*****************************************************************************************************************************/
#ifndef DOXYGEN_SHOULD_SKIP_THIS
void FromPlug(FbxControlSetPlug *pPlug);
void ToPlug(FbxControlSetPlug *pPlug);
private:
FbxControlSet();
~FbxControlSet();
FbxCharacter* mCharacter;
EType mType;
bool mUseAxis;
bool mLockTransform;
bool mLock3DPick;
FbxControlSetLink mControlSetLink[FbxCharacter::eNodeIdCount]; // Except floor node IDs!
FbxEffector mEffector[FbxEffector::eNodeIdCount];
FbxNode* mEffectorAux[FbxEffector::eNodeIdCount][FbxEffector::eSetIdCount-1];
FBXSDK_FRIEND_NEW();
friend class FbxCharacter;
friend class FbxNode;
#endif /* !DOXYGEN_SHOULD_SKIP_THIS *****************************************************************************************/
};
/** Plug class for control set.
* \nosubgrouping
*/
class FBXSDK_DLL FbxControlSetPlug : public FbxObject
{
FBXSDK_OBJECT_DECLARE(FbxControlSetPlug, FbxObject);
public:
//! EType property of control set.
FbxPropertyT<FbxControlSet::EType> ControlSetType;
//! Use axis flag.
FbxPropertyT<FbxBool> UseAxis;
//! Reference character.
FbxPropertyT<FbxReference> Character;
protected:
void Construct(const FbxObject* pFrom) override;
void ConstructProperties(bool pForceSet) override;
FbxStringList GetTypeFlags() const override;
private:
FbxArray<FbxProperty> mFKBuf;
FbxArray<FbxProperty> mIKBuf;
friend class FbxScene;
friend class FbxControlSet;
};
inline EFbxType FbxTypeOf(const FbxControlSet::EType&){ return eFbxEnum; }
#include <fbxsdk/fbxsdk_nsend.h>
#endif /* _FBXSDK_SCENE_CONSTRAINT_CONTROL_SET_H_ */