mirror of https://github.com/AxioDL/metaforce.git
Initial CCollisionActor imps
This commit is contained in:
parent
39040b5ab3
commit
04619dd960
|
@ -7,7 +7,7 @@ namespace urde
|
||||||
const CCollisionPrimitive::Type CCollidableOBBTreeGroup::sType(CCollidableOBBTreeGroup::SetStaticTableIndex, "CCollidableOBBTreeGroup");
|
const CCollisionPrimitive::Type CCollidableOBBTreeGroup::sType(CCollidableOBBTreeGroup::SetStaticTableIndex, "CCollidableOBBTreeGroup");
|
||||||
u32 CCollidableOBBTreeGroup::sTableIndex = -1;
|
u32 CCollidableOBBTreeGroup::sTableIndex = -1;
|
||||||
|
|
||||||
CCollidableOBBTreeGroup::CCollidableOBBTreeGroup(CInputStream& in)
|
CCollidableOBBTreeGroupContainer::CCollidableOBBTreeGroupContainer(CInputStream& in)
|
||||||
{
|
{
|
||||||
u32 treeCount = in.readUint32Big();
|
u32 treeCount = in.readUint32Big();
|
||||||
x0_trees.reserve(treeCount);
|
x0_trees.reserve(treeCount);
|
||||||
|
@ -24,6 +24,17 @@ CCollidableOBBTreeGroup::CCollidableOBBTreeGroup(CInputStream& in)
|
||||||
x10_aabbs.push_back(CCollidableOBBTree(tree.get(), CMaterialList()).CalculateLocalAABox());
|
x10_aabbs.push_back(CCollidableOBBTree(tree.get(), CMaterialList()).CalculateLocalAABox());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CCollidableOBBTreeGroupContainer::CCollidableOBBTreeGroupContainer(const zeus::CVector3f &, const zeus::CVector3f &)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
CCollidableOBBTreeGroup::CCollidableOBBTreeGroup(const CCollidableOBBTreeGroupContainer* container,
|
||||||
|
const CMaterialList& matList)
|
||||||
|
: CCollisionPrimitive(matList)
|
||||||
|
, x10_container(container)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
void CCollidableOBBTreeGroup::ResetTestStats() const
|
void CCollidableOBBTreeGroup::ResetTestStats() const
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -36,12 +47,12 @@ u32 CCollidableOBBTreeGroup::GetTableIndex() const
|
||||||
|
|
||||||
zeus::CAABox CCollidableOBBTreeGroup::CalculateAABox(const zeus::CTransform& xf) const
|
zeus::CAABox CCollidableOBBTreeGroup::CalculateAABox(const zeus::CTransform& xf) const
|
||||||
{
|
{
|
||||||
return x10_aabbs.front().getTransformedAABox(xf);
|
return x10_container->x20_aabox.getTransformedAABox(xf);
|
||||||
}
|
}
|
||||||
|
|
||||||
zeus::CAABox CCollidableOBBTreeGroup::CalculateLocalAABox() const
|
zeus::CAABox CCollidableOBBTreeGroup::CalculateLocalAABox() const
|
||||||
{
|
{
|
||||||
return x10_aabbs.front();
|
return x10_container->x20_aabox;
|
||||||
}
|
}
|
||||||
|
|
||||||
FourCC CCollidableOBBTreeGroup::GetPrimType() const
|
FourCC CCollidableOBBTreeGroup::GetPrimType() const
|
||||||
|
@ -98,7 +109,7 @@ CFactoryFnReturn FCollidableOBBTreeGroupFactory(const SObjectTag &tag, CInputStr
|
||||||
const CVParamTransfer& vparms,
|
const CVParamTransfer& vparms,
|
||||||
CObjectReference* selfRef)
|
CObjectReference* selfRef)
|
||||||
{
|
{
|
||||||
return TToken<CCollidableOBBTreeGroup>::GetIObjObjectFor(std::make_unique<CCollidableOBBTreeGroup>(in));
|
return TToken<CCollidableOBBTreeGroupContainer>::GetIObjObjectFor(std::make_unique<CCollidableOBBTreeGroupContainer>(in));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,15 +9,25 @@
|
||||||
|
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
|
class CCollidableOBBTreeGroupContainer
|
||||||
|
{
|
||||||
|
friend class CCollidableOBBTreeGroup;
|
||||||
|
std::vector<std::unique_ptr<COBBTree>> x0_trees;
|
||||||
|
std::vector<zeus::CAABox> x10_aabbs;
|
||||||
|
zeus::CAABox x20_aabox;
|
||||||
|
public:
|
||||||
|
CCollidableOBBTreeGroupContainer(CInputStream& in);
|
||||||
|
CCollidableOBBTreeGroupContainer(const zeus::CVector3f&, const zeus::CVector3f&);
|
||||||
|
};
|
||||||
|
|
||||||
class CCollidableOBBTreeGroup : public CCollisionPrimitive
|
class CCollidableOBBTreeGroup : public CCollisionPrimitive
|
||||||
{
|
{
|
||||||
static const Type sType;
|
static const Type sType;
|
||||||
static u32 sTableIndex;
|
static u32 sTableIndex;
|
||||||
std::vector<std::unique_ptr<COBBTree>> x0_trees;
|
const CCollidableOBBTreeGroupContainer* x10_container;
|
||||||
std::vector<zeus::CAABox> x10_aabbs;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CCollidableOBBTreeGroup(CInputStream& in);
|
CCollidableOBBTreeGroup(CInputStream& in);
|
||||||
|
CCollidableOBBTreeGroup(const CCollidableOBBTreeGroupContainer*, const CMaterialList&);
|
||||||
virtual ~CCollidableOBBTreeGroup() {}
|
virtual ~CCollidableOBBTreeGroup() {}
|
||||||
|
|
||||||
void ResetTestStats() const;
|
void ResetTestStats() const;
|
||||||
|
|
|
@ -1,5 +1,10 @@
|
||||||
#include "CCollisionActor.hpp"
|
#include "CCollisionActor.hpp"
|
||||||
|
#include "Camera/CGameCamera.hpp"
|
||||||
|
#include "CStateManager.hpp"
|
||||||
#include "World/CActorParameters.hpp"
|
#include "World/CActorParameters.hpp"
|
||||||
|
#include "Collision/CCollidableOBBTreeGroup.hpp"
|
||||||
|
#include "Collision/CCollidableSphere.hpp"
|
||||||
|
#include "TCastTo.hpp"
|
||||||
|
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
|
@ -12,24 +17,54 @@ CCollisionActor::CCollisionActor(TUniqueId uid1, TAreaId aId, TUniqueId uid2, co
|
||||||
: CPhysicsActor(uid1, active, "CollisionActor", CEntityInfo(aId, CEntity::NullConnectionList),
|
: CPhysicsActor(uid1, active, "CollisionActor", CEntityInfo(aId, CEntity::NullConnectionList),
|
||||||
zeus::CTransform::Identity(), CModelData::CModelDataNull(), gkDefaultCollisionActorMaterials,
|
zeus::CTransform::Identity(), CModelData::CModelDataNull(), gkDefaultCollisionActorMaterials,
|
||||||
zeus::CAABox::skNullBox, SMoverData(mass), CActorParameters::None(), 0.3f, 0.1f)
|
zeus::CAABox::skNullBox, SMoverData(mass), CActorParameters::None(), 0.3f, 0.1f)
|
||||||
|
, x258_primitiveType(EPrimitiveType::OBBTreeGroup)
|
||||||
|
, x25c_owner(uid2)
|
||||||
|
, x260_boxSize(vec1)
|
||||||
|
, x26c_(vec2)
|
||||||
|
, x278_obbContainer(new CCollidableOBBTreeGroupContainer(vec1, vec2))
|
||||||
|
, x27c_obbTreeGroupPrimitive(new CCollidableOBBTreeGroup(x278_obbContainer.get(), GetMaterialList()))
|
||||||
{
|
{
|
||||||
|
SetCoefficientOfRestitutionModifier(0.5f);
|
||||||
|
SetCallTouch(false);
|
||||||
|
SetMaterialFilter(CMaterialFilter::MakeIncludeExclude(
|
||||||
|
{EMaterialTypes::Solid}, {EMaterialTypes::CollisionActor, EMaterialTypes::ThirtyEight}));
|
||||||
}
|
}
|
||||||
|
|
||||||
CCollisionActor::CCollisionActor(TUniqueId uid1, TAreaId aId, TUniqueId uid2, const zeus::CVector3f& vec, bool active,
|
CCollisionActor::CCollisionActor(TUniqueId uid1, TAreaId aId, TUniqueId uid2, const zeus::CVector3f& boxSize,
|
||||||
float mass)
|
bool active, float mass)
|
||||||
: CPhysicsActor(uid1, active, "CollisionActor", CEntityInfo(aId, CEntity::NullConnectionList),
|
: CPhysicsActor(uid1, active, "CollisionActor", CEntityInfo(aId, CEntity::NullConnectionList),
|
||||||
zeus::CTransform::Identity(), CModelData::CModelDataNull(), gkDefaultCollisionActorMaterials,
|
zeus::CTransform::Identity(), CModelData::CModelDataNull(), gkDefaultCollisionActorMaterials,
|
||||||
zeus::CAABox::skNullBox, SMoverData(mass), CActorParameters::None(), 0.3f, 0.1f)
|
zeus::CAABox::skNullBox, SMoverData(mass), CActorParameters::None(), 0.3f, 0.1f)
|
||||||
|
, x258_primitiveType(EPrimitiveType::AABox)
|
||||||
|
, x25c_owner(uid2)
|
||||||
|
, x260_boxSize(boxSize)
|
||||||
|
, x280_aaboxPrimitive(new CCollidableAABox(zeus::CAABox(-0.5f * boxSize, 0.5f * boxSize),
|
||||||
|
CMaterialList(EMaterialTypes::Solid, EMaterialTypes::ThirtyEight)))
|
||||||
{
|
{
|
||||||
|
SetCoefficientOfRestitutionModifier(0.5f);
|
||||||
|
SetCallTouch(false);
|
||||||
|
SetMaterialFilter(CMaterialFilter::MakeIncludeExclude(
|
||||||
|
{EMaterialTypes::Solid}, {EMaterialTypes::CollisionActor, EMaterialTypes::ThirtyEight}));
|
||||||
}
|
}
|
||||||
|
|
||||||
CCollisionActor::CCollisionActor(TUniqueId uid1, TAreaId aId, TUniqueId uid2, bool active, float, float mass)
|
CCollisionActor::CCollisionActor(TUniqueId uid1, TAreaId aId, TUniqueId uid2, bool active, float radius, float mass)
|
||||||
: CPhysicsActor(uid1, active, "CollisionActor", CEntityInfo(aId, CEntity::NullConnectionList),
|
: CPhysicsActor(uid1, active, "CollisionActor", CEntityInfo(aId, CEntity::NullConnectionList),
|
||||||
zeus::CTransform::Identity(), CModelData::CModelDataNull(), gkDefaultCollisionActorMaterials,
|
zeus::CTransform::Identity(), CModelData::CModelDataNull(), gkDefaultCollisionActorMaterials,
|
||||||
zeus::CAABox::skNullBox, SMoverData(mass), CActorParameters::None(), 0.3f, 0.1f)
|
zeus::CAABox::skNullBox, SMoverData(mass), CActorParameters::None(), 0.3f, 0.1f)
|
||||||
|
, x258_primitiveType(EPrimitiveType::Sphere)
|
||||||
|
, x25c_owner(uid2)
|
||||||
|
, x284_spherePrimitive(new CCollidableSphere(zeus::CSphere(zeus::CVector3f::skZero, radius),
|
||||||
|
CMaterialList(EMaterialTypes::ThirtyEight, EMaterialTypes::Solid)))
|
||||||
|
, x288_sphereRadius(radius)
|
||||||
{
|
{
|
||||||
|
SetCoefficientOfRestitutionModifier(0.5f);
|
||||||
|
SetCallTouch(false);
|
||||||
|
SetMaterialFilter(CMaterialFilter::MakeIncludeExclude(
|
||||||
|
{EMaterialTypes::Solid}, {EMaterialTypes::CollisionActor, EMaterialTypes::ThirtyEight}));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CCollisionActor::Accept(IVisitor& visitor) { visitor.Visit(this); }
|
||||||
|
|
||||||
void CCollisionActor::AcceptScriptMsg(EScriptObjectMessage, TUniqueId, CStateManager&) {}
|
void CCollisionActor::AcceptScriptMsg(EScriptObjectMessage, TUniqueId, CStateManager&) {}
|
||||||
|
|
||||||
CHealthInfo* CCollisionActor::HealthInfo() { return &x28c_healthInfo; }
|
CHealthInfo* CCollisionActor::HealthInfo() { return &x28c_healthInfo; }
|
||||||
|
@ -43,4 +78,59 @@ const CDamageVulnerability* CCollisionActor::GetDamageVulnerability(const zeus::
|
||||||
}
|
}
|
||||||
|
|
||||||
void CCollisionActor::SetDamageVulnerability(const CDamageVulnerability& vuln) { x294_damageVuln = vuln; }
|
void CCollisionActor::SetDamageVulnerability(const CDamageVulnerability& vuln) { x294_damageVuln = vuln; }
|
||||||
|
|
||||||
|
zeus::CVector3f CCollisionActor::GetScanObjectIndicatorPosition(const CStateManager& mgr)
|
||||||
|
{
|
||||||
|
const CGameCamera* gameCamera = static_cast<const CGameCamera*>(mgr.GetCameraManager()->GetCurrentCamera(mgr));
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
const CCollisionPrimitive* CCollisionActor::GetCollisionPrimitive() const
|
||||||
|
{
|
||||||
|
if (x258_primitiveType == EPrimitiveType::OBBTreeGroup)
|
||||||
|
return x27c_obbTreeGroupPrimitive.get();
|
||||||
|
if (x258_primitiveType == EPrimitiveType::AABox)
|
||||||
|
return x280_aaboxPrimitive.get();
|
||||||
|
return x284_spherePrimitive.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
zeus::CTransform CCollisionActor::GetPrimitiveTransform() const
|
||||||
|
{
|
||||||
|
zeus::CTransform xf = x34_transform;
|
||||||
|
xf.origin = CPhysicsActor::GetPrimitiveTransform().origin;
|
||||||
|
return xf;
|
||||||
|
}
|
||||||
|
|
||||||
|
rstl::optional_object<zeus::CAABox> CCollisionActor::GetTouchBounds() const
|
||||||
|
{
|
||||||
|
rstl::optional_object<zeus::CAABox> aabox;
|
||||||
|
if (x258_primitiveType == EPrimitiveType::OBBTreeGroup)
|
||||||
|
aabox = {x27c_obbTreeGroupPrimitive->CalculateAABox(x34_transform)};
|
||||||
|
else if (x258_primitiveType == EPrimitiveType::AABox)
|
||||||
|
aabox = {x280_aaboxPrimitive->CalculateAABox(x34_transform)};
|
||||||
|
else if (x258_primitiveType == EPrimitiveType::Sphere)
|
||||||
|
aabox = {x280_aaboxPrimitive->CalculateAABox(x34_transform)};
|
||||||
|
|
||||||
|
aabox->accumulateBounds(aabox->max + x304_extendedTouchBounds);
|
||||||
|
aabox->accumulateBounds(aabox->min - x304_extendedTouchBounds);
|
||||||
|
|
||||||
|
return aabox;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CCollisionActor::OnScanStateChanged(CActor::EScanState state, CStateManager& mgr)
|
||||||
|
{
|
||||||
|
TCastToPtr<CActor> actor = mgr.ObjectById(x25c_owner);
|
||||||
|
if (actor)
|
||||||
|
actor->OnScanStateChanged(state, mgr);
|
||||||
|
|
||||||
|
CActor::OnScanStateChanged(state, mgr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CCollisionActor::Touch(CActor& actor, CStateManager& mgr)
|
||||||
|
{
|
||||||
|
x2fc_lastTouched = actor.GetUniqueId();
|
||||||
|
mgr.SendScriptMsgAlways(x25c_owner, GetUniqueId(), EScriptObjectMessage::InternalMessage08);
|
||||||
|
}
|
||||||
|
|
||||||
|
zeus::CVector3f CCollisionActor::GetOrbitPosition(const CStateManager&) const { return GetTouchBounds()->center(); }
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,35 +4,58 @@
|
||||||
#include "World/CPhysicsActor.hpp"
|
#include "World/CPhysicsActor.hpp"
|
||||||
#include "World/CHealthInfo.hpp"
|
#include "World/CHealthInfo.hpp"
|
||||||
#include "World/CDamageVulnerability.hpp"
|
#include "World/CDamageVulnerability.hpp"
|
||||||
#include "Collision/CCollidableOBBTreeGroup.hpp"
|
|
||||||
#include "Collision/CCollidableSphere.hpp"
|
|
||||||
|
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
|
class CCollidableSphere;
|
||||||
|
class CCollidableOBBTreeGroup;
|
||||||
|
class CCollidableOBBTreeGroupContainer;
|
||||||
class CCollisionActor : public CPhysicsActor
|
class CCollisionActor : public CPhysicsActor
|
||||||
{
|
{
|
||||||
u32 x258_;
|
enum class EPrimitiveType
|
||||||
TUniqueId x25c_;
|
{
|
||||||
|
OBBTreeGroup,
|
||||||
|
AABox,
|
||||||
|
Sphere
|
||||||
|
};
|
||||||
|
|
||||||
|
EPrimitiveType x258_primitiveType;
|
||||||
|
TUniqueId x25c_owner;
|
||||||
zeus::CVector3f x260_boxSize;
|
zeus::CVector3f x260_boxSize;
|
||||||
std::unique_ptr<CCollidableOBBTreeGroup> x278_obbTG1;
|
zeus::CVector3f x26c_;
|
||||||
std::unique_ptr<CCollidableOBBTreeGroup> x27c_obbTG2;
|
std::unique_ptr<CCollidableOBBTreeGroupContainer> x278_obbContainer;
|
||||||
std::unique_ptr<CCollidableSphere> x284_;
|
std::unique_ptr<CCollidableOBBTreeGroup> x27c_obbTreeGroupPrimitive;
|
||||||
|
std::unique_ptr<CCollidableAABox> x280_aaboxPrimitive;
|
||||||
|
std::unique_ptr<CCollidableSphere> x284_spherePrimitive;
|
||||||
float x288_sphereRadius;
|
float x288_sphereRadius;
|
||||||
CHealthInfo x28c_healthInfo = CHealthInfo(0.f);
|
CHealthInfo x28c_healthInfo = CHealthInfo(0.f);
|
||||||
CDamageVulnerability x294_damageVuln = CDamageVulnerability::NormalVulnerabilty();
|
CDamageVulnerability x294_damageVuln = CDamageVulnerability::NormalVulnerabilty();
|
||||||
TUniqueId x2fc_lastTouched;
|
TUniqueId x2fc_lastTouched = kInvalidUniqueId;
|
||||||
EWeaponCollisionResponseTypes x300_responseType;
|
EWeaponCollisionResponseTypes x300_responseType = EWeaponCollisionResponseTypes::EnemyNormal;
|
||||||
|
zeus::CVector3f x304_extendedTouchBounds = zeus::CVector3f::skZero;
|
||||||
public:
|
public:
|
||||||
CCollisionActor(TUniqueId, TAreaId, TUniqueId, const zeus::CVector3f&, const zeus::CVector3f&, bool, float);
|
CCollisionActor(TUniqueId, TAreaId, TUniqueId, const zeus::CVector3f&, const zeus::CVector3f&, bool, float);
|
||||||
CCollisionActor(TUniqueId, TAreaId, TUniqueId, const zeus::CVector3f&, bool, float);
|
CCollisionActor(TUniqueId, TAreaId, TUniqueId, const zeus::CVector3f&, bool, float);
|
||||||
CCollisionActor(TUniqueId, TAreaId, TUniqueId, bool, float, float);
|
CCollisionActor(TUniqueId, TAreaId, TUniqueId, bool, float, float);
|
||||||
|
|
||||||
|
void Accept(IVisitor &visitor);
|
||||||
void AcceptScriptMsg(EScriptObjectMessage, TUniqueId, CStateManager&);
|
void AcceptScriptMsg(EScriptObjectMessage, TUniqueId, CStateManager&);
|
||||||
CHealthInfo* HealthInfo();
|
CHealthInfo* HealthInfo();
|
||||||
const CDamageVulnerability* GetDamageVulnerability() const;
|
const CDamageVulnerability* GetDamageVulnerability() const;
|
||||||
const CDamageVulnerability* GetDamageVulnerability(const zeus::CVector3f&, const zeus::CVector3f&,
|
const CDamageVulnerability* GetDamageVulnerability(const zeus::CVector3f&, const zeus::CVector3f&,
|
||||||
const CDamageInfo&) const;
|
const CDamageInfo&) const;
|
||||||
|
void OnScanStateChanged(EScanState, CStateManager &);
|
||||||
|
|
||||||
|
void Touch(CActor &, CStateManager &);
|
||||||
|
zeus::CVector3f GetOrbitPosition(const CStateManager &) const;
|
||||||
|
const CCollisionPrimitive* GetCollisionPrimitive() const;
|
||||||
|
zeus::CTransform GetPrimitiveTransform() const;
|
||||||
|
rstl::optional_object<zeus::CAABox> GetTouchBounds() const;
|
||||||
void SetDamageVulnerability(const CDamageVulnerability& vuln);
|
void SetDamageVulnerability(const CDamageVulnerability& vuln);
|
||||||
|
const zeus::CVector3f& GetBoxSize() const { return x260_boxSize; }
|
||||||
|
TUniqueId GetOwnerId() const { return x25c_owner; }
|
||||||
|
TUniqueId GetLastTouchedObject() const { return x2fc_lastTouched; }
|
||||||
|
zeus::CVector3f GetScanObjectIndicatorPosition(const CStateManager &);
|
||||||
|
void SetExtendedTouchBounds(const zeus::CVector3f& boundExt) { x304_extendedTouchBounds = boundExt; }
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,7 @@ zeus::CVector3f CPhysicsActor::GetAimPosition(const CStateManager&, float dt) co
|
||||||
|
|
||||||
void CPhysicsActor::CollidedWith(const TUniqueId&, const CCollisionInfoList&, CStateManager&) {}
|
void CPhysicsActor::CollidedWith(const TUniqueId&, const CCollisionInfoList&, CStateManager&) {}
|
||||||
|
|
||||||
const CCollisionPrimitive& CPhysicsActor::GetCollisionPrimitive() const { return x1c0_collisionPrimitive; }
|
const CCollisionPrimitive* CPhysicsActor::GetCollisionPrimitive() const { return &x1c0_collisionPrimitive; }
|
||||||
|
|
||||||
zeus::CTransform CPhysicsActor::GetPrimitiveTransform() const
|
zeus::CTransform CPhysicsActor::GetPrimitiveTransform() const
|
||||||
{
|
{
|
||||||
|
@ -70,7 +70,7 @@ void CPhysicsActor::SetBoundingBox(const zeus::CAABox& box)
|
||||||
|
|
||||||
zeus::CAABox CPhysicsActor::GetMotionVolume(float dt) const
|
zeus::CAABox CPhysicsActor::GetMotionVolume(float dt) const
|
||||||
{
|
{
|
||||||
zeus::CAABox aabox = GetCollisionPrimitive().CalculateAABox(GetPrimitiveTransform());
|
zeus::CAABox aabox = GetCollisionPrimitive()->CalculateAABox(GetPrimitiveTransform());
|
||||||
zeus::CVector3f velocity = CalculateNewVelocityWR_UsingImpulses();
|
zeus::CVector3f velocity = CalculateNewVelocityWR_UsingImpulses();
|
||||||
|
|
||||||
const zeus::CVector3f dv = (dt * velocity);
|
const zeus::CVector3f dv = (dt * velocity);
|
||||||
|
@ -144,6 +144,11 @@ void CPhysicsActor::SetInertiaTensorScalar(float tensor)
|
||||||
xf4_inertiaTensorRecip = 1.0f / tensor;
|
xf4_inertiaTensorRecip = 1.0f / tensor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CPhysicsActor::SetCoefficientOfRestitutionModifier(float mod)
|
||||||
|
{
|
||||||
|
x244_restitutionCoefModifier = mod;
|
||||||
|
}
|
||||||
|
|
||||||
void CPhysicsActor::SetMass(float mass)
|
void CPhysicsActor::SetMass(float mass)
|
||||||
{
|
{
|
||||||
xe8_mass = mass;
|
xe8_mass = mass;
|
||||||
|
|
|
@ -114,7 +114,7 @@ public:
|
||||||
void Render(const CStateManager& mgr) const;
|
void Render(const CStateManager& mgr) const;
|
||||||
zeus::CVector3f GetOrbitPosition(const CStateManager&) const;
|
zeus::CVector3f GetOrbitPosition(const CStateManager&) const;
|
||||||
zeus::CVector3f GetAimPosition(const CStateManager&, float val) const;
|
zeus::CVector3f GetAimPosition(const CStateManager&, float val) const;
|
||||||
virtual const CCollisionPrimitive& GetCollisionPrimitive() const;
|
virtual const CCollisionPrimitive* GetCollisionPrimitive() const;
|
||||||
virtual zeus::CTransform GetPrimitiveTransform() const;
|
virtual zeus::CTransform GetPrimitiveTransform() const;
|
||||||
virtual void CollidedWith(const TUniqueId&, const CCollisionInfoList&, CStateManager&);
|
virtual void CollidedWith(const TUniqueId&, const CCollisionInfoList&, CStateManager&);
|
||||||
virtual float GetStepUpHeight() const;
|
virtual float GetStepUpHeight() const;
|
||||||
|
@ -135,6 +135,7 @@ public:
|
||||||
CMotionState GetMotionState() const;
|
CMotionState GetMotionState() const;
|
||||||
void SetMotionState(const CMotionState& mst);
|
void SetMotionState(const CMotionState& mst);
|
||||||
void SetInertiaTensorScalar(float tensor);
|
void SetInertiaTensorScalar(float tensor);
|
||||||
|
void SetCoefficientOfRestitutionModifier(float);
|
||||||
void SetMass(float mass);
|
void SetMass(float mass);
|
||||||
void SetAngularVelocityOR(const zeus::CAxisAngle& angVel);
|
void SetAngularVelocityOR(const zeus::CAxisAngle& angVel);
|
||||||
zeus::CAxisAngle GetAngularVelocityOR() const;
|
zeus::CAxisAngle GetAngularVelocityOR() const;
|
||||||
|
|
|
@ -288,7 +288,7 @@ void CPlayer::Teleport(const zeus::CTransform& xf, CStateManager& mgr, bool) {}
|
||||||
|
|
||||||
zeus::CTransform CPlayer::CreateTransformFromMovementDirection() const { return {}; }
|
zeus::CTransform CPlayer::CreateTransformFromMovementDirection() const { return {}; }
|
||||||
|
|
||||||
const CCollisionPrimitive& CPlayer::GetCollisionPrimitive() const { return CPhysicsActor::GetCollisionPrimitive(); }
|
const CCollisionPrimitive* CPlayer::GetCollisionPrimitive() const { return CPhysicsActor::GetCollisionPrimitive(); }
|
||||||
|
|
||||||
zeus::CTransform CPlayer::GetPrimitiveTransform() const { return {}; }
|
zeus::CTransform CPlayer::GetPrimitiveTransform() const { return {}; }
|
||||||
|
|
||||||
|
|
|
@ -396,7 +396,7 @@ public:
|
||||||
float GetStepDownHeight() const;
|
float GetStepDownHeight() const;
|
||||||
void Teleport(const zeus::CTransform& xf, CStateManager& mgr, bool);
|
void Teleport(const zeus::CTransform& xf, CStateManager& mgr, bool);
|
||||||
zeus::CTransform CreateTransformFromMovementDirection() const;
|
zeus::CTransform CreateTransformFromMovementDirection() const;
|
||||||
const CCollisionPrimitive& GetCollisionPrimitive() const;
|
const CCollisionPrimitive* GetCollisionPrimitive() const;
|
||||||
zeus::CTransform GetPrimitiveTransform() const;
|
zeus::CTransform GetPrimitiveTransform() const;
|
||||||
bool CollidedWith(TUniqueId, const CCollisionInfoList&, CStateManager& mgr);
|
bool CollidedWith(TUniqueId, const CCollisionInfoList&, CStateManager& mgr);
|
||||||
float GetActualFirstPersonMaxVelocity() const;
|
float GetActualFirstPersonMaxVelocity() const;
|
||||||
|
|
Loading…
Reference in New Issue