1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-16 15:29:55 +00:00
openmw/components/nif/physics.hpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

718 lines
16 KiB
C++
Raw Normal View History

#ifndef OPENMW_COMPONENTS_NIF_PHYSICS_HPP
#define OPENMW_COMPONENTS_NIF_PHYSICS_HPP
2023-08-31 21:00:37 +00:00
#include "niftypes.hpp"
2022-08-15 21:04:54 +00:00
#include "record.hpp"
#include "recordptr.hpp"
#include <osg/Quat>
#include <osg/Vec3f>
#include <osg/Vec4f>
#include <cstdint>
#include <vector>
// This header contains certain record definitions
// specific to Bethesda implementation of Havok physics
namespace Nif
{
2022-08-15 21:04:54 +00:00
class NIFStream;
2022-10-09 10:39:43 +00:00
class Reader;
2022-08-15 21:04:54 +00:00
/// Non-record data types
struct bhkWorldObjCInfoProperty
{
2023-08-31 21:00:37 +00:00
uint32_t mData;
uint32_t mSize;
uint32_t mCapacityAndFlags;
void read(NIFStream* nif);
};
enum class BroadPhaseType : uint8_t
{
BroadPhase_Invalid = 0,
BroadPhase_Entity = 1,
BroadPhase_Phantom = 2,
BroadPhase_Border = 3
};
struct bhkWorldObjectCInfo
{
BroadPhaseType mPhaseType;
bhkWorldObjCInfoProperty mProperty;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif);
};
struct HavokMaterial
{
2023-08-31 21:00:37 +00:00
uint32_t mMaterial;
void read(NIFStream* nif);
};
struct HavokFilter
{
2023-08-31 21:00:37 +00:00
uint8_t mLayer;
uint8_t mFlags;
uint16_t mGroup;
void read(NIFStream* nif);
};
struct hkSubPartData
{
HavokMaterial mHavokMaterial;
2023-08-31 21:00:37 +00:00
uint32_t mNumVertices;
HavokFilter mHavokFilter;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif);
};
enum class hkResponseType : uint8_t
{
Response_Invalid = 0,
Response_SimpleContact = 1,
Response_Reporting = 2,
Response_None = 3
};
struct bhkEntityCInfo
{
hkResponseType mResponseType;
2023-08-31 21:00:37 +00:00
uint16_t mProcessContactDelay;
void read(NIFStream* nif);
2021-11-13 17:04:21 +00:00
};
2021-11-13 16:23:37 +00:00
struct hkpMoppCode
{
osg::Vec4f mOffset;
2023-08-31 21:00:37 +00:00
uint8_t mBuildType;
std::vector<uint8_t> mData;
2021-11-13 16:23:37 +00:00
void read(NIFStream* nif);
};
struct TriangleData
{
2023-08-31 21:00:37 +00:00
std::array<uint16_t, 3> mTriangle;
uint16_t mWeldingInfo;
osg::Vec3f mNormal;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif);
};
2023-02-24 17:29:28 +00:00
struct bhkMeshMaterial
{
HavokMaterial mHavokMaterial;
HavokFilter mHavokFilter;
2023-08-31 21:00:37 +00:00
2023-02-24 17:29:28 +00:00
void read(NIFStream* nif);
};
struct bhkQsTransform
{
osg::Vec4f mTranslation;
osg::Quat mRotation;
2023-08-31 21:00:37 +00:00
2023-02-24 17:29:28 +00:00
void read(NIFStream* nif);
};
struct bhkCMSBigTri
{
2023-08-31 21:00:37 +00:00
std::array<uint16_t, 3> mTriangle;
uint32_t mMaterial;
uint16_t mWeldingInfo;
2023-02-24 17:29:28 +00:00
void read(NIFStream* nif);
};
struct bhkCMSChunk
{
osg::Vec4f mTranslation;
2023-08-31 21:00:37 +00:00
uint32_t mMaterialIndex;
uint16_t mReference;
uint16_t mTransformIndex;
std::vector<uint16_t> mVertices;
std::vector<uint16_t> mIndices;
std::vector<uint16_t> mStrips;
std::vector<uint16_t> mWeldingInfos;
2023-02-24 17:29:28 +00:00
void read(NIFStream* nif);
};
2021-11-13 16:59:30 +00:00
enum class hkMotionType : uint8_t
{
Motion_Invalid = 0,
Motion_Dynamic = 1,
Motion_SphereInertia = 2,
Motion_SphereStabilized = 3,
Motion_BoxInertia = 4,
Motion_BoxStabilized = 5,
Motion_Keyframed = 6,
Motion_Fixed = 7,
Motion_ThinBox = 8,
Motion_Character = 9
};
2022-09-22 18:26:05 +00:00
2021-11-13 16:59:30 +00:00
enum class hkDeactivatorType : uint8_t
{
Deactivator_Invalid = 0,
Deactivator_Never = 1,
Deactivator_Spatial = 2
};
enum class hkSolverDeactivation : uint8_t
{
SolverDeactivation_Invalid = 0,
SolverDeactivation_Off = 1,
SolverDeactivation_Low = 2,
SolverDeactivation_Medium = 3,
SolverDeactivation_High = 4,
SolverDeactivation_Max = 5
};
2022-09-22 18:26:05 +00:00
2021-11-13 16:59:30 +00:00
enum class hkQualityType : uint8_t
{
Quality_Invalid = 0,
Quality_Fixed = 1,
Quality_Keyframed = 2,
Quality_Debris = 3,
Quality_Moving = 4,
Quality_Critical = 5,
Quality_Bullet = 6,
Quality_User = 7,
Quality_Character = 8,
Quality_KeyframedReport = 9
};
2022-09-22 18:26:05 +00:00
2021-11-13 16:59:30 +00:00
struct bhkRigidBodyCInfo
{
HavokFilter mHavokFilter;
hkResponseType mResponseType;
2023-08-31 21:00:37 +00:00
uint16_t mProcessContactDelay;
2021-11-13 16:59:30 +00:00
osg::Vec4f mTranslation;
osg::Quat mRotation;
osg::Vec4f mLinearVelocity;
osg::Vec4f mAngularVelocity;
2023-08-31 21:00:37 +00:00
Matrix3 mInertiaTensor;
2021-11-13 16:59:30 +00:00
osg::Vec4f mCenter;
float mMass;
float mLinearDamping;
float mAngularDamping;
float mTimeFactor{ 1.f };
float mGravityFactor{ 1.f };
float mFriction;
float mRollingFrictionMult;
float mRestitution;
float mMaxLinearVelocity;
float mMaxAngularVelocity;
float mPenetrationDepth;
hkMotionType mMotionType;
hkDeactivatorType mDeactivatorType;
bool mEnableDeactivation{ true };
hkSolverDeactivation mSolverDeactivation;
hkQualityType mQualityType;
2023-08-31 21:00:37 +00:00
uint8_t mAutoRemoveLevel;
uint8_t mResponseModifierFlags;
uint8_t mNumContactPointShapeKeys;
bool mForceCollidedOntoPPU;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif);
};
2022-09-22 18:26:05 +00:00
2023-07-15 02:21:51 +00:00
enum class ConstraintPriority : uint32_t
{
Priority_Invalid = 0,
Priority_PhysicsTime = 1,
Priority_TimeOfImpact = 3
};
struct bhkConstraintCInfo
{
bhkEntityPtr mEntityA;
bhkEntityPtr mEntityB;
2023-07-15 02:21:51 +00:00
ConstraintPriority mPriority;
2023-08-31 21:00:37 +00:00
2023-07-15 02:21:51 +00:00
void read(NIFStream* nif);
void post(Reader& nif);
};
2023-07-15 03:09:34 +00:00
enum class hkMotorType : uint8_t
{
Motor_None = 0,
Motor_Position = 1,
Motor_Velocity = 2,
Motor_SpringDamper = 3
};
struct bhkPositionConstraintMotor
{
float mMinForce, mMaxForce;
float mTau;
float mDamping;
float mProportionalRecoveryVelocity;
float mConstantRecoveryVelocity;
bool mEnabled;
2023-08-31 21:00:37 +00:00
2023-07-15 03:09:34 +00:00
void read(NIFStream* nif);
};
struct bhkVelocityConstraintMotor
{
float mMinForce, mMaxForce;
float mTau;
float mTargetVelocity;
bool mUseVelocityTarget;
bool mEnabled;
2023-08-31 21:00:37 +00:00
2023-07-15 03:09:34 +00:00
void read(NIFStream* nif);
};
struct bhkSpringDamperConstraintMotor
{
float mMinForce, mMaxForce;
float mSpringConstant;
float mSpringDamping;
bool mEnabled;
2023-08-31 21:00:37 +00:00
2023-07-15 03:09:34 +00:00
void read(NIFStream* nif);
};
struct bhkConstraintMotorCInfo
{
hkMotorType mType;
bhkPositionConstraintMotor mPositionMotor;
bhkVelocityConstraintMotor mVelocityMotor;
bhkSpringDamperConstraintMotor mSpringDamperMotor;
2023-08-31 21:00:37 +00:00
2023-07-15 03:09:34 +00:00
void read(NIFStream* nif);
};
struct bhkRagdollConstraintCInfo
{
struct Data
2023-07-15 03:09:34 +00:00
{
osg::Vec4f mPivot;
osg::Vec4f mPlane;
osg::Vec4f mTwist;
osg::Vec4f mMotor;
};
Data mDataA;
Data mDataB;
2023-07-15 03:09:34 +00:00
float mConeMaxAngle;
float mPlaneMinAngle, mPlaneMaxAngle;
float mTwistMinAngle, mTwistMaxAngle;
float mMaxFriction;
bhkConstraintMotorCInfo mMotor;
2023-08-31 21:00:37 +00:00
2023-07-15 03:09:34 +00:00
void read(NIFStream* nif);
};
2023-07-15 03:33:21 +00:00
struct bhkHingeConstraintCInfo
{
struct HingeData
{
osg::Vec4f mPivot;
osg::Vec4f mAxis;
osg::Vec4f mPerpAxis1;
osg::Vec4f mPerpAxis2;
};
2023-08-31 21:00:37 +00:00
2023-07-15 03:33:21 +00:00
HingeData mDataA;
HingeData mDataB;
2023-08-31 21:00:37 +00:00
2023-07-15 03:33:21 +00:00
void read(NIFStream* nif);
};
2023-07-20 02:19:23 +00:00
struct bhkLimitedHingeConstraintCInfo
{
struct HingeData
{
osg::Vec4f mPivot;
osg::Vec4f mAxis;
osg::Vec4f mPerpAxis1;
osg::Vec4f mPerpAxis2;
};
2023-08-31 21:00:37 +00:00
2023-07-20 02:19:23 +00:00
HingeData mDataA;
HingeData mDataB;
float mMinAngle, mMaxAngle;
float mMaxFriction;
bhkConstraintMotorCInfo mMotor;
2023-08-31 21:00:37 +00:00
2023-07-20 02:19:23 +00:00
void read(NIFStream* nif);
};
struct bhkBallAndSocketConstraintCInfo
{
osg::Vec4f mPivotA, mPivotB;
void read(NIFStream* nif);
};
struct bhkStiffSpringConstraintCInfo
{
osg::Vec4f mPivotA, mPivotB;
float mLength;
void read(NIFStream* nif);
};
/// Record types
2022-09-22 18:26:05 +00:00
// Abstract Bethesda Havok object
struct bhkRefObject : public Record
{
};
// Abstract serializable Bethesda Havok object
struct bhkSerializable : public bhkRefObject
{
};
2022-09-22 18:26:05 +00:00
// Abstract narrowphase collision detection object
struct bhkShape : public bhkSerializable
{
};
// Abstract bhkShape collection
struct bhkShapeCollection : public bhkShape
{
};
// Abstract physics system
struct bhkSystem : public Record
{
};
// Generic collision object
struct NiCollisionObject : public Record
{
// The node that references this object
NiAVObjectPtr mTarget;
void read(NIFStream* nif) override { mTarget.read(nif); }
void post(Reader& nif) override { mTarget.post(nif); }
2021-11-10 17:16:05 +00:00
};
2021-11-13 16:23:37 +00:00
// Bethesda Havok-specific collision object
struct bhkCollisionObject : public NiCollisionObject
2022-09-22 18:26:05 +00:00
{
2023-08-31 21:00:37 +00:00
uint16_t mFlags;
2021-11-13 16:23:37 +00:00
bhkWorldObjectPtr mBody;
2022-09-22 18:26:05 +00:00
2021-11-13 16:23:37 +00:00
void read(NIFStream* nif) override;
void post(Reader& nif) override
2022-09-22 18:26:05 +00:00
{
NiCollisionObject::post(nif);
mBody.post(nif);
2022-09-22 18:26:05 +00:00
}
};
struct bhkNPCollisionObject : NiCollisionObject
{
uint16_t mFlags;
bhkSystemPtr mData;
uint32_t mBodyID;
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
2023-09-20 02:37:52 +00:00
struct bhkBlendCollisionObject : bhkCollisionObject
{
float mHeirGain;
float mVelGain;
void read(NIFStream* nif) override;
};
struct bhkPhysicsSystem : public bhkSystem
{
std::vector<uint8_t> mData;
void read(NIFStream* nif) override;
};
struct bhkRagdollSystem : public bhkSystem
{
std::vector<uint8_t> mData;
void read(NIFStream* nif) override;
};
2021-11-13 16:23:37 +00:00
// Abstract Havok shape info record
struct bhkWorldObject : public bhkSerializable
{
bhkShapePtr mShape;
HavokFilter mHavokFilter;
bhkWorldObjectCInfo mWorldObjectInfo;
2023-08-31 21:00:37 +00:00
2021-11-13 16:23:37 +00:00
void read(NIFStream* nif) override;
void post(Reader& nif) override;
2022-09-22 18:26:05 +00:00
};
// Abstract
2021-11-10 17:16:05 +00:00
struct bhkEntity : public bhkWorldObject
2022-09-22 18:26:05 +00:00
{
bhkEntityCInfo mInfo;
2023-08-31 21:00:37 +00:00
2021-11-10 17:16:05 +00:00
void read(NIFStream* nif) override;
2021-11-13 16:23:37 +00:00
};
// Bethesda extension of hkpBvTreeShape
// hkpBvTreeShape adds a bounding volume tree to an hkpShapeCollection
struct bhkBvTreeShape : public bhkShape
{
bhkShapePtr mShape;
2023-08-31 21:00:37 +00:00
2021-11-13 16:23:37 +00:00
void read(NIFStream* nif) override;
void post(Reader& nif) override;
2021-11-13 16:23:37 +00:00
};
// bhkBvTreeShape with Havok MOPP code
struct bhkMoppBvTreeShape : public bhkBvTreeShape
{
float mScale;
hkpMoppCode mMopp;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif) override;
};
// Bethesda triangle strip-based Havok shape collection
struct bhkNiTriStripsShape : public bhkShape
2022-09-22 18:26:05 +00:00
{
HavokMaterial mHavokMaterial;
float mRadius;
2023-08-31 21:00:37 +00:00
uint32_t mGrowBy;
osg::Vec4f mScale{ 1.f, 1.f, 1.f, 0.f };
NiTriStripsDataList mData;
2023-08-31 21:00:37 +00:00
std::vector<HavokFilter> mHavokFilters;
void read(NIFStream* nif) override;
void post(Reader& nif) override;
2022-09-22 18:26:05 +00:00
};
// Bethesda packed triangle strip-based Havok shape collection
struct bhkPackedNiTriStripsShape : public bhkShapeCollection
2022-09-22 18:26:05 +00:00
{
std::vector<hkSubPartData> mSubshapes;
2023-08-31 21:00:37 +00:00
uint32_t mUserData;
float mRadius;
osg::Vec4f mScale;
hkPackedNiTriStripsDataPtr mData;
2022-09-22 18:26:05 +00:00
void read(NIFStream* nif) override;
void post(Reader& nif) override;
2022-09-22 18:26:05 +00:00
};
// bhkPackedNiTriStripsShape data block
struct hkPackedNiTriStripsData : public bhkShapeCollection
2022-09-22 18:26:05 +00:00
{
std::vector<TriangleData> mTriangles;
std::vector<osg::Vec3f> mVertices;
std::vector<hkSubPartData> mSubshapes;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif) override;
2022-09-22 18:26:05 +00:00
};
// Abstract
struct bhkSphereRepShape : public bhkShape
{
HavokMaterial mHavokMaterial;
2023-08-31 21:00:37 +00:00
2021-11-13 17:04:21 +00:00
void read(NIFStream* nif) override;
};
// Abstract
struct bhkConvexShape : public bhkSphereRepShape
{
float mRadius;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif) override;
};
// A list of convex shapes sharing the same properties
struct bhkConvexListShape : public bhkShape
{
bhkShapeList mSubShapes;
HavokMaterial mMaterial;
float mRadius;
bhkWorldObjCInfoProperty mChildShapeProperty;
bool mUseCachedAABB;
float mClosestPointMinDistance;
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
struct bhkConvexSweepShape : bhkShape
{
bhkConvexShape mShape;
HavokMaterial mMaterial;
float mRadius;
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
// A convex shape built from vertices
struct bhkConvexVerticesShape : public bhkConvexShape
2022-09-22 18:26:05 +00:00
{
bhkWorldObjCInfoProperty mVerticesProperty;
bhkWorldObjCInfoProperty mNormalsProperty;
std::vector<osg::Vec4f> mVertices;
std::vector<osg::Vec4f> mNormals;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif) override;
2022-09-22 18:26:05 +00:00
};
2023-02-08 10:22:58 +00:00
struct bhkConvexTransformShape : public bhkShape
{
bhkShapePtr mShape;
HavokMaterial mHavokMaterial;
float mRadius;
osg::Matrixf mTransform;
2023-08-31 21:00:37 +00:00
2023-02-08 10:22:58 +00:00
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
2022-09-22 18:26:05 +00:00
// A box
struct bhkBoxShape : public bhkConvexShape
{
osg::Vec3f mExtents;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif) override;
2022-09-22 18:26:05 +00:00
};
2022-09-22 18:26:05 +00:00
// A capsule
struct bhkCapsuleShape : public bhkConvexShape
2022-09-22 18:26:05 +00:00
{
osg::Vec3f mPoint1, mPoint2;
float mRadius1, mRadius2;
void read(NIFStream* nif) override;
2022-09-22 18:26:05 +00:00
};
2023-09-20 01:08:11 +00:00
// A cylinder
struct bhkCylinderShape : public bhkConvexShape
{
osg::Vec4f mVertexA, mVertexB;
float mCylinderRadius;
void read(NIFStream* nif) override;
};
// A sphere
using bhkSphereShape = bhkConvexShape;
2022-09-22 18:26:05 +00:00
// A list of shapes
struct bhkListShape : public bhkShapeCollection
{
bhkShapeList mSubshapes;
HavokMaterial mHavokMaterial;
bhkWorldObjCInfoProperty mChildShapeProperty;
bhkWorldObjCInfoProperty mChildFilterProperty;
std::vector<HavokFilter> mHavokFilters;
2023-08-31 21:00:37 +00:00
void read(NIFStream* nif) override;
};
2022-09-22 18:26:05 +00:00
2023-02-24 17:29:28 +00:00
struct bhkCompressedMeshShape : public bhkShape
{
NiAVObjectPtr mTarget;
2023-08-31 21:00:37 +00:00
uint32_t mUserData;
2023-02-24 17:29:28 +00:00
float mRadius;
osg::Vec4f mScale;
bhkCompressedMeshShapeDataPtr mData;
2023-08-31 21:00:37 +00:00
2023-02-24 17:29:28 +00:00
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
struct bhkCompressedMeshShapeData : public bhkRefObject
{
2023-08-31 21:00:37 +00:00
uint32_t mBitsPerIndex, mBitsPerWIndex;
uint32_t mMaskWIndex, mMaskIndex;
2023-02-24 17:29:28 +00:00
float mError;
osg::Vec4f mAabbMin, mAabbMax;
2023-08-31 21:00:37 +00:00
uint8_t mWeldingType;
uint8_t mMaterialType;
2023-02-24 17:29:28 +00:00
std::vector<bhkMeshMaterial> mMaterials;
std::vector<bhkQsTransform> mChunkTransforms;
std::vector<osg::Vec4f> mBigVerts;
std::vector<bhkCMSBigTri> mBigTris;
std::vector<bhkCMSChunk> mChunks;
void read(NIFStream* nif) override;
};
2021-11-13 16:59:30 +00:00
struct bhkRigidBody : public bhkEntity
{
bhkRigidBodyCInfo mInfo;
bhkSerializableList mConstraints;
2023-08-31 21:00:37 +00:00
uint32_t mBodyFlags;
2021-11-13 16:59:30 +00:00
void read(NIFStream* nif) override;
};
2023-07-10 22:27:05 +00:00
struct bhkSimpleShapePhantom : public bhkWorldObject
{
osg::Matrixf mTransform;
2023-08-31 21:00:37 +00:00
2023-07-10 22:27:05 +00:00
void read(NIFStream* nif) override;
};
2023-07-15 02:21:51 +00:00
// Abstract constraint
struct bhkConstraint : public bhkSerializable
{
bhkConstraintCInfo mInfo;
2023-08-31 21:00:37 +00:00
2023-07-15 02:21:51 +00:00
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
2023-07-15 03:09:34 +00:00
struct bhkRagdollConstraint : public bhkConstraint
{
bhkRagdollConstraintCInfo mConstraint;
2023-08-31 21:00:37 +00:00
2023-07-15 03:09:34 +00:00
void read(NIFStream* nif) override;
};
2023-07-15 03:33:21 +00:00
struct bhkHingeConstraint : public bhkConstraint
{
bhkHingeConstraintCInfo mConstraint;
2023-08-31 21:00:37 +00:00
2023-07-15 03:33:21 +00:00
void read(NIFStream* nif) override;
};
2023-07-20 02:19:23 +00:00
struct bhkLimitedHingeConstraint : public bhkConstraint
{
bhkLimitedHingeConstraintCInfo mConstraint;
2023-08-31 21:00:37 +00:00
2023-07-20 02:19:23 +00:00
void read(NIFStream* nif) override;
};
struct bhkBallAndSocketConstraint : bhkConstraint
{
bhkBallAndSocketConstraintCInfo mConstraint;
void read(NIFStream* nif) override;
};
struct bhkStiffSpringConstraint : bhkConstraint
{
bhkStiffSpringConstraintCInfo mConstraint;
void read(NIFStream* nif) override;
};
} // Namespace
#endif