mirror of
				https://github.com/PrimeDecomp/prime.git
				synced 2025-10-26 00:50:23 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			211 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			211 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef _CPHYSICSACTOR
 | |
| #define _CPHYSICSACTOR
 | |
| 
 | |
| #include "types.h"
 | |
| 
 | |
| #include "MetroidPrime/CActor.hpp"
 | |
| #include "MetroidPrime/CAxisAngle.hpp"
 | |
| #include "MetroidPrime/CPhysicsState.hpp"
 | |
| 
 | |
| #include "Kyoto/Math/CAABox.hpp"
 | |
| #include "Kyoto/Math/CMatrix3f.hpp"
 | |
| #include "Kyoto/Math/CNUQuaternion.hpp"
 | |
| #include "Kyoto/Math/CVector3f.hpp"
 | |
| 
 | |
| #include "Collision/CCollidableAABox.hpp"
 | |
| 
 | |
| #include "rstl/optional_object.hpp"
 | |
| 
 | |
| struct SMoverData {
 | |
|   CVector3f x0_velocity;
 | |
|   CAxisAngle xc_angularVelocity;
 | |
|   CVector3f x18_momentum;
 | |
|   CAxisAngle x24_;
 | |
|   float x30_mass;
 | |
| 
 | |
|   SMoverData(float mass, const CVector3f& velocity = CVector3f::Zero(),
 | |
|              const CAxisAngle& angularVelocity = CAxisAngle::Identity(),
 | |
|              const CVector3f& momentum = CVector3f::Zero(),
 | |
|              const CAxisAngle& unk = CAxisAngle::Identity())
 | |
|   : x0_velocity(velocity)
 | |
|   , xc_angularVelocity(angularVelocity)
 | |
|   , x18_momentum(momentum)
 | |
|   , x24_(unk)
 | |
|   , x30_mass(mass) {}
 | |
| };
 | |
| 
 | |
| class CMotionState {
 | |
| public:
 | |
|   CMotionState(const CVector3f& translation, const CNUQuaternion& orientation,
 | |
|                const CVector3f& velocity, const CAxisAngle& angularMomentum)
 | |
|   : x0_translation(translation)
 | |
|   , xc_orientation(orientation)
 | |
|   , x1c_velocity(velocity)
 | |
|   , x28_angularMomentum(angularMomentum) {}
 | |
| 
 | |
|   const CVector3f& GetTranslation() const { return x0_translation; }
 | |
|   const CNUQuaternion& GetOrientation() const { return xc_orientation; }
 | |
|   const CVector3f& GetVelocity() const { return x1c_velocity; }
 | |
|   const CAxisAngle& GetAngularMomentum() const { return x28_angularMomentum; }
 | |
| 
 | |
| private:
 | |
|   CVector3f x0_translation;
 | |
|   CNUQuaternion xc_orientation;
 | |
|   CVector3f x1c_velocity;
 | |
|   CAxisAngle x28_angularMomentum;
 | |
| };
 | |
| CHECK_SIZEOF(CMotionState, 0x34)
 | |
| 
 | |
| class CCollisionInfoList;
 | |
| 
 | |
| class CPhysicsActor : public CActor {
 | |
|   static const float kGravityAccel;
 | |
| 
 | |
| public:
 | |
|   CPhysicsActor(TUniqueId uid, bool active, const rstl::string& name, const CEntityInfo& info,
 | |
|                 const CTransform4f& xf, const CModelData& mData, const CMaterialList& matList,
 | |
|                 const CAABox& aabb, const SMoverData& moverData, const CActorParameters& actParams,
 | |
|                 float stepUp, float stepDown);
 | |
| 
 | |
|   // CActor
 | |
|   ~CPhysicsActor() override;
 | |
|   void Render(const CStateManager&) const override;
 | |
|   CVector3f GetOrbitPosition(const CStateManager& mgr) const override;
 | |
|   CVector3f GetAimPosition(const CStateManager& mgr, float val) const override;
 | |
| 
 | |
|   // CPhysicsActor
 | |
|   virtual const CCollisionPrimitive* GetCollisionPrimitive() const;
 | |
|   virtual CTransform4f GetPrimitiveTransform() const;
 | |
|   virtual void CollidedWith(const TUniqueId& id, const CCollisionInfoList& list,
 | |
|                             CStateManager& mgr);
 | |
|   virtual float GetStepDownHeight() const;
 | |
|   virtual float GetStepUpHeight() const;
 | |
|   virtual float GetWeight() const;
 | |
|   float GetMass() const { return xe8_mass; }
 | |
|   void SetMass(float mass);
 | |
|   void SetInertiaTensorScalar(float tensor);
 | |
| 
 | |
|   const CAABox& GetBaseBoundingBox() const;
 | |
|   CAABox GetBoundingBox() const;
 | |
|   void SetBoundingBox(const CAABox& box);
 | |
|   CAABox GetMotionVolume(float dt) const;
 | |
| 
 | |
|   void ApplyImpulseWR(const CVector3f& impulse, const CAxisAngle& angularImpulse);
 | |
|   void ApplyTorqueWR(const CVector3f& torque);
 | |
|   void ApplyForceWR(const CVector3f& force, const CAxisAngle& torque);
 | |
| 
 | |
|   void ApplyImpulseOR(const CVector3f& impulse, const CAxisAngle& angularImpulse);
 | |
|   void ApplyForceOR(const CVector3f& impulse, const CAxisAngle& torque);
 | |
| 
 | |
|   void MoveCollisionPrimitive(const CVector3f&);
 | |
|   void SetVelocityWR(const CVector3f&);
 | |
|   void SetAngularVelocityWR(const CAxisAngle& angVel);
 | |
|   void SetVelocityOR(const CVector3f& vel);
 | |
|   CAxisAngle GetAngularVelocityOR() const;
 | |
|   void SetAngularVelocityOR(const CAxisAngle& angleVel);
 | |
|   void ClearForcesAndTorques();
 | |
|   void ClearImpulses();
 | |
|   void ComputeDerivedQuantities();
 | |
|   void UseCollisionImpulses();
 | |
|   bool WillMove(const CStateManager& mgr);
 | |
|   void Stop();
 | |
| 
 | |
|   CVector3f GetPrimitiveOffset() const;
 | |
|   const bool IsStandardCollider() const { return xf9_standardCollider; } // name and type?
 | |
|   void SetStandardCollider(const bool v) { xf9_standardCollider = v; } // name and type?
 | |
|   const CVector3f& GetConstantForceWR() const { return xfc_constantForce; }
 | |
|   void SetConstantForceWR(const CVector3f& force) { xfc_constantForce = force; }
 | |
|   const CAxisAngle& GetAngularMomentumWR() const { return x108_angularMomentum; }
 | |
|   void SetAngularMomentumWR(const CAxisAngle& angularMomentum) {
 | |
|     x108_angularMomentum = angularMomentum;
 | |
|   }
 | |
|   const CVector3f& GetVelocityWR() const { return x138_velocity; }
 | |
|   const CVector3f& GetMomentumWR() const { return x150_momentum; }
 | |
|   void SetMomentumWR(const CVector3f& momentum) { x150_momentum = momentum; }
 | |
|   const CVector3f& GetForceWR() const { return x15c_force; }
 | |
|   void SetForceWR(const CVector3f& force) { x15c_force = force; }
 | |
|   const CVector3f& GetImpulseWR() const { return x168_impulse; }
 | |
|   void SetImpulseWR(const CVector3f& impulse) { x168_impulse = impulse; }
 | |
|   const CAxisAngle& GetTorqueWR() const { return x174_torque; }
 | |
|   void SetTorqueWR(const CAxisAngle& torque) { x174_torque = torque; }
 | |
|   const CAxisAngle& GetAngularImpulseWR() const { return x180_angularImpulse; }
 | |
|   void SetAngularImpulseWR(const CAxisAngle& angularImpulse) {
 | |
|     x180_angularImpulse = angularImpulse;
 | |
|   }
 | |
|   void SetLastNonCollidingState(const CMotionState& state) { x1f4_lastNonCollidingState = state; }
 | |
| 
 | |
|   float GetCoefficientOfRestitutionModifier() const;
 | |
|   void SetCoefficientOfRestitutionModifier(float modifier);
 | |
|   float GetCollisionAccuracyModifier() const;
 | |
|   void SetCollisionAccuracyModifier(float modifier);
 | |
|   float GetMaximumCollisionVelocity() const;
 | |
|   void SetMaxVelocityAfterCollision(float velocity);
 | |
| 
 | |
|   CPhysicsState GetPhysicsState() const;
 | |
|   void SetPhysicsState(const CPhysicsState& state);
 | |
|   CMotionState GetMotionState() const;
 | |
|   void SetMotionState(const CMotionState& state);
 | |
|   CVector3f CalculateNewVelocityWR_UsingImpulses() const;
 | |
|   CMotionState PredictMotion(float dt) const;
 | |
|   CMotionState PredictAngularMotion(float dt) const;
 | |
|   CMotionState PredictLinearMotion(float dt) const;
 | |
|   CMotionState PredictMotion_Internal(float dt) const;
 | |
|   void AddMotionState(const CMotionState& state);
 | |
|   bool GetMovable() const { return xf8_24_movable; }
 | |
|   void SetMovable(bool v) { xf8_24_movable = v; }
 | |
| 
 | |
|   void MoveToWR(const CVector3f&, float);
 | |
|   void MoveToInOneFrameWR(const CVector3f&, float);
 | |
|   CVector3f GetMoveToORImpulseWR(const CVector3f& impulse, float d) const;
 | |
|   CVector3f GetRotateToORAngularMomentumWR(const CQuaternion& q, float d) const;
 | |
|   void RotateToWR(const CQuaternion&, float);
 | |
| 
 | |
|   void MoveInOneFrameOR(const CVector3f& trans, float d);
 | |
|   void RotateInOneFrameOR(const CQuaternion&, float);
 | |
| 
 | |
|   void MoveToOR(const CVector3f&, float);
 | |
|   void RotateToOR(const CQuaternion&, float);
 | |
| 
 | |
|   CVector3f GetTotalForceWR() const;
 | |
|   CVector3f GetConstantTotalForceWR() const { return x15c_force + x150_momentum; }
 | |
| 
 | |
|   static float GravityConstant() { return kGravityAccel; }
 | |
| 
 | |
| private:
 | |
|   float xe8_mass;
 | |
|   float xec_massRecip;
 | |
|   float xf0_inertiaTensor;
 | |
|   float xf4_inertiaTensorRecip;
 | |
|   bool xf8_24_movable : 1;
 | |
|   bool xf8_25_angularEnabled : 1;
 | |
|   uchar xf9_standardCollider;
 | |
|   CVector3f xfc_constantForce;
 | |
|   CAxisAngle x108_angularMomentum;
 | |
|   CMatrix3f x114_;
 | |
|   CVector3f x138_velocity;
 | |
|   CAxisAngle x144_angularVelocity;
 | |
|   CVector3f x150_momentum;
 | |
|   CVector3f x15c_force;
 | |
|   CVector3f x168_impulse;
 | |
|   CAxisAngle x174_torque;
 | |
|   CAxisAngle x180_angularImpulse;
 | |
|   CVector3f x18c_moveImpulse;
 | |
|   CAxisAngle x198_moveAngularImpulse;
 | |
|   CAABox x1a4_baseBoundingBox;
 | |
|   CCollidableAABox x1c0_collisionPrimitive;
 | |
|   CVector3f x1e8_primitiveOffset;
 | |
|   CMotionState x1f4_lastNonCollidingState;
 | |
|   rstl::optional_object< CVector3f > x228_lastFloorPlaneNormal;
 | |
|   float x238_maximumCollisionVelocity;
 | |
|   float x23c_stepUpHeight;
 | |
|   float x240_stepDownHeight;
 | |
|   float x244_restitutionCoefModifier;
 | |
|   float x248_collisionAccuracyModifier;
 | |
|   uint x24c_numTicksStuck;
 | |
|   uint x250_numTicksPartialUpdate;
 | |
|   uint x254_;
 | |
| };
 | |
| CHECK_SIZEOF(CPhysicsActor, 0x258)
 | |
| 
 | |
| #endif // _CPHYSICSACTOR
 |