mirror of https://github.com/AxioDL/metaforce.git
More CThardus imps, add reference CTevPass imps
This commit is contained in:
parent
617844efce
commit
9f5f0abab4
|
@ -36,30 +36,18 @@ SViewport g_Viewport = {
|
||||||
u32 CGraphics::g_FrameCounter = 0;
|
u32 CGraphics::g_FrameCounter = 0;
|
||||||
|
|
||||||
const zeus::CMatrix3f CGraphics::skCubeBasisMats[] = {
|
const zeus::CMatrix3f CGraphics::skCubeBasisMats[] = {
|
||||||
/* Right */
|
/* Right */
|
||||||
{0.f, 1.f, 0.f,
|
{0.f, 1.f, 0.f, 1.f, 0.f, 0.f, 0.f, 0.f, -1.f},
|
||||||
1.f, 0.f, 0.f,
|
/* Left */
|
||||||
0.f, 0.f, -1.f},
|
{0.f, -1.f, 0.f, -1.f, 0.f, 0.f, 0.f, 0.f, -1.f},
|
||||||
/* Left */
|
/* Up */
|
||||||
{0.f, -1.f, 0.f,
|
{1.f, 0.f, 0.f, 0.f, 0.f, -1.f, 0.f, 1.f, 0.f},
|
||||||
-1.f, 0.f, 0.f,
|
/* Down */
|
||||||
0.f, 0.f, -1.f},
|
{1.f, 0.f, 0.f, 0.f, 0.f, 1.f, 0.f, -1.f, 0.f},
|
||||||
/* Up */
|
/* Back */
|
||||||
{1.f, 0.f, 0.f,
|
{1.f, 0.f, 0.f, 0.f, -1.f, 0.f, 0.f, 0.f, -1.f},
|
||||||
0.f, 0.f, -1.f,
|
/* Forward */
|
||||||
0.f, 1.f, 0.f},
|
{-1.f, 0.f, 0.f, 0.f, 1.f, 0.f, 0.f, 0.f, -1.f},
|
||||||
/* Down */
|
|
||||||
{1.f, 0.f, 0.f,
|
|
||||||
0.f, 0.f, 1.f,
|
|
||||||
0.f, -1.f, 0.f},
|
|
||||||
/* Back */
|
|
||||||
{1.f, 0.f, 0.f,
|
|
||||||
0.f, -1.f, 0.f,
|
|
||||||
0.f, 0.f, -1.f},
|
|
||||||
/* Forward */
|
|
||||||
{-1.f, 0.f, 0.f,
|
|
||||||
0.f, 1.f, 0.f,
|
|
||||||
0.f, 0.f, -1.f},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void CGraphics::DisableAllLights() {
|
void CGraphics::DisableAllLights() {
|
||||||
|
@ -462,4 +450,48 @@ boo::IGraphicsCommandQueue* CGraphics::g_BooMainCommandQueue = nullptr;
|
||||||
boo::ObjToken<boo::ITextureR> CGraphics::g_SpareTexture;
|
boo::ObjToken<boo::ITextureR> CGraphics::g_SpareTexture;
|
||||||
const boo::SystemChar* CGraphics::g_BooPlatformName = nullptr;
|
const boo::SystemChar* CGraphics::g_BooPlatformName = nullptr;
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a564c(
|
||||||
|
{GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_RASC},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_RASA});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a5698(
|
||||||
|
{GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_RASC, GX::TevColorArg::CC_C0, GX::TevColorArg::CC_ZERO},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_RASA, GX::TevAlphaArg::CA_A0, GX::TevAlphaArg::CA_ZERO});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a5e70(
|
||||||
|
{GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_C0},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_A0});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a5ebc(
|
||||||
|
{GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_RASC, GX::TevColorArg::CC_TEXC, GX::TevColorArg::CC_ZERO},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_RASA, GX::TevAlphaArg::CA_TEXA, GX::TevAlphaArg::CA_ZERO});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a5f08(
|
||||||
|
{GX::TevColorArg::CC_RASC, GX::TevColorArg::CC_TEXC, GX::TevColorArg::CC_TEXA, GX::TevColorArg::CC_ZERO},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_RASA});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a5f54(
|
||||||
|
{GX::TevColorArg::CC_RASC, GX::TevColorArg::CC_ONE, GX::TevColorArg::CC_TEXC, GX::TevColorArg::CC_ZERO},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_TEXA, GX::TevAlphaArg::CA_RASA, GX::TevAlphaArg::CA_ZERO});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a5fa0(
|
||||||
|
{GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_TEXC},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_TEXA});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass804bfcc0(
|
||||||
|
{GX::TevColorArg::CC_C0, GX::TevColorArg::CC_TEXC, GX::TevColorArg::CC_RASC, GX::TevColorArg::CC_ZERO},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_RASA});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a5fec(
|
||||||
|
{GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_RASC},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_TEXA, GX::TevAlphaArg::CA_RASA, GX::TevAlphaArg::CA_ZERO});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a6038(
|
||||||
|
{GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_TEXC, GX::TevColorArg::CC_RASC, GX::TevColorArg::CC_ZERO},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_KONST, GX::TevAlphaArg::CA_RASA, GX::TevAlphaArg::CA_ZERO});
|
||||||
|
|
||||||
|
const CTevCombiners::CTevPass CGraphics::sTevPass805a6084(
|
||||||
|
{GX::TevColorArg::CC_ZERO, GX::TevColorArg::CC_CPREV, GX::TevColorArg::CC_APREV, GX::TevColorArg::CC_ZERO},
|
||||||
|
{GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_ZERO, GX::TevAlphaArg::CA_APREV});
|
||||||
} // namespace urde
|
} // namespace urde
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
|
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
|
|
||||||
|
#include "DataSpec/DNACommon/GX.hpp"
|
||||||
|
|
||||||
#include <boo/graphicsdev/IGraphicsCommandQueue.hpp>
|
#include <boo/graphicsdev/IGraphicsCommandQueue.hpp>
|
||||||
#include <boo/graphicsdev/IGraphicsDataFactory.hpp>
|
#include <boo/graphicsdev/IGraphicsDataFactory.hpp>
|
||||||
|
|
||||||
|
@ -183,6 +185,46 @@ enum class ETexelFormat {
|
||||||
#define CUBEMAP_RES 256
|
#define CUBEMAP_RES 256
|
||||||
#define CUBEMAP_MIPS 6
|
#define CUBEMAP_MIPS 6
|
||||||
|
|
||||||
|
static s32 sNextUniquePass = 0;
|
||||||
|
namespace CTevCombiners {
|
||||||
|
struct CTevOp {
|
||||||
|
bool x0_clamp = true;
|
||||||
|
GX::TevOp x4_op = GX::TevOp::TEV_ADD;
|
||||||
|
GX::TevBias x8_bias = GX::TevBias::TB_ZERO;
|
||||||
|
GX::TevScale xc_scale = GX::TevScale::CS_SCALE_1;
|
||||||
|
GX::TevRegID xc_regId = GX::TevRegID::TEVPREV;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct ColorPass {
|
||||||
|
GX::TevColorArg x0_a;
|
||||||
|
GX::TevColorArg x4_b;
|
||||||
|
GX::TevColorArg x8_c;
|
||||||
|
GX::TevColorArg xc_d;
|
||||||
|
};
|
||||||
|
struct AlphaPass {
|
||||||
|
GX::TevAlphaArg x0_a;
|
||||||
|
GX::TevAlphaArg x4_b;
|
||||||
|
GX::TevAlphaArg x8_c;
|
||||||
|
GX::TevAlphaArg xc_d;
|
||||||
|
};
|
||||||
|
|
||||||
|
class CTevPass {
|
||||||
|
u32 x0_id;
|
||||||
|
ColorPass x4_colorPass;
|
||||||
|
AlphaPass x14_alphaPass;
|
||||||
|
CTevOp x24_colorOp;
|
||||||
|
CTevOp x38_alphaOp;
|
||||||
|
|
||||||
|
public:
|
||||||
|
CTevPass(const ColorPass& colPass, const AlphaPass& alphaPass, const CTevOp& colorOp = CTevOp(), const CTevOp alphaOp = CTevOp())
|
||||||
|
: x0_id(++sNextUniquePass)
|
||||||
|
, x4_colorPass(colPass)
|
||||||
|
, x14_alphaPass(alphaPass)
|
||||||
|
, x24_colorOp(colorOp)
|
||||||
|
, x38_alphaOp(alphaOp) {}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
class CGraphics {
|
class CGraphics {
|
||||||
public:
|
public:
|
||||||
struct CProjectionState {
|
struct CProjectionState {
|
||||||
|
@ -312,7 +354,28 @@ public:
|
||||||
g_BooMainCommandQueue->drawInstances(start, count, instCount, startInst);
|
g_BooMainCommandQueue->drawInstances(start, count, instCount, startInst);
|
||||||
}
|
}
|
||||||
static void DrawArray(size_t start, size_t count) { g_BooMainCommandQueue->draw(start, count); }
|
static void DrawArray(size_t start, size_t count) { g_BooMainCommandQueue->draw(start, count); }
|
||||||
static void DrawArrayIndexed(size_t start, size_t count) { g_BooMainCommandQueue->drawIndexed(start, count); }
|
static void DrawArrayIndexed(size_t start, size_t count) { g_BooMainCommandQueue->drawIndexed(start, count); }\
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a564c;
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a5698;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a5e70;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a5ebc;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a5f08;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a5f54;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a5fa0;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass804bfcc0;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a5fec;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a6038;
|
||||||
|
|
||||||
|
static const CTevCombiners::CTevPass sTevPass805a6084;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class VTX>
|
template <class VTX>
|
||||||
|
|
|
@ -4,19 +4,22 @@
|
||||||
#include "Runtime/Camera/CFirstPersonCamera.hpp"
|
#include "Runtime/Camera/CFirstPersonCamera.hpp"
|
||||||
#include "Runtime/Collision/CCollisionActor.hpp"
|
#include "Runtime/Collision/CCollisionActor.hpp"
|
||||||
#include "Runtime/Collision/CCollisionActorManager.hpp"
|
#include "Runtime/Collision/CCollisionActorManager.hpp"
|
||||||
|
#include "Runtime/CSimplePool.hpp"
|
||||||
#include "Runtime/CStateManager.hpp"
|
#include "Runtime/CStateManager.hpp"
|
||||||
|
#include "Runtime/MP1/CSamusHud.hpp"
|
||||||
#include "Runtime/MP1/World/CThardusRockProjectile.hpp"
|
#include "Runtime/MP1/World/CThardusRockProjectile.hpp"
|
||||||
#include "Runtime/World/CActorParameters.hpp"
|
#include "Runtime/World/CActorParameters.hpp"
|
||||||
#include "Runtime/World/CDestroyableRock.hpp"
|
#include "Runtime/World/CDestroyableRock.hpp"
|
||||||
#include "Runtime/World/CGameLight.hpp"
|
#include "Runtime/World/CGameLight.hpp"
|
||||||
#include "Runtime/World/CPatternedInfo.hpp"
|
#include "Runtime/World/CPatternedInfo.hpp"
|
||||||
#include "Runtime/World/CPlayer.hpp"
|
#include "Runtime/World/CPlayer.hpp"
|
||||||
|
#include "Runtime/World/CScriptDistanceFog.hpp"
|
||||||
#include "Runtime/World/CScriptWaypoint.hpp"
|
#include "Runtime/World/CScriptWaypoint.hpp"
|
||||||
#include "Runtime/World/CWorld.hpp"
|
#include "Runtime/World/CWorld.hpp"
|
||||||
#include "Runtime/MP1/CSamusHud.hpp"
|
|
||||||
|
|
||||||
#include "TCastTo.hpp" // Generated file, do not modify include path
|
#include "TCastTo.hpp" // Generated file, do not modify include path
|
||||||
|
|
||||||
|
#include <DataSpec/DNAMP1/SFX/IceWorld.h>
|
||||||
namespace urde::MP1 {
|
namespace urde::MP1 {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -110,7 +113,8 @@ CThardus::CThardus(TUniqueId uid, std::string_view name, const CEntityInfo& info
|
||||||
xd0_damageMag = 0.f;
|
xd0_damageMag = 0.f;
|
||||||
x50c_baseDamageMag = 0.f;
|
x50c_baseDamageMag = 0.f;
|
||||||
x8f4_waypoints.reserve(16);
|
x8f4_waypoints.reserve(16);
|
||||||
x91c_.Lock();
|
x91c_flareTexture = g_SimplePool->GetObj("Thermal_Spot_2"sv);
|
||||||
|
x91c_flareTexture.Lock();
|
||||||
x403_26_stateControlledMassiveDeath = false;
|
x403_26_stateControlledMassiveDeath = false;
|
||||||
x460_knockBackController.SetAutoResetImpulse(false);
|
x460_knockBackController.SetAutoResetImpulse(false);
|
||||||
SetMass(100000.f);
|
SetMass(100000.f);
|
||||||
|
@ -133,7 +137,7 @@ void CThardus::sub801dcfa4(CStateManager& mgr) {}
|
||||||
|
|
||||||
void CThardus::Think(float dt, CStateManager& mgr) {
|
void CThardus::Think(float dt, CStateManager& mgr) {
|
||||||
if (!GetActive() && x450_bodyController->GetActive()) {
|
if (!GetActive() && x450_bodyController->GetActive()) {
|
||||||
x91c_.Lock();
|
x91c_flareTexture.Lock();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (x7c8_) {
|
if (x7c8_) {
|
||||||
|
@ -203,7 +207,8 @@ void CThardus::Think(float dt, CStateManager& mgr) {
|
||||||
x688_ = false;
|
x688_ = false;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
UpdateNonDestroyableCollisionActorMaterials(EUpdateMaterialMode::Remove, EMaterialTypes::ProjectilePassthrough, mgr);
|
UpdateNonDestroyableCollisionActorMaterials(EUpdateMaterialMode::Remove, EMaterialTypes::ProjectilePassthrough,
|
||||||
|
mgr);
|
||||||
for (size_t i = 0; i < x610_destroyableRocks.size(); ++i) {
|
for (size_t i = 0; i < x610_destroyableRocks.size(); ++i) {
|
||||||
if (CActor* act = static_cast<CActor*>(mgr.ObjectById(x610_destroyableRocks[i]))) {
|
if (CActor* act = static_cast<CActor*>(mgr.ObjectById(x610_destroyableRocks[i]))) {
|
||||||
if (!x688_ && !x93c_ && !x909_ && !x93d_) {
|
if (!x688_ && !x93c_ && !x909_ && !x93d_) {
|
||||||
|
@ -394,7 +399,7 @@ void CThardus::AcceptScriptMsg(EScriptObjectMessage msg, TUniqueId uid, CStateMa
|
||||||
rstl::reserved_vector<TUniqueId, 16> wpIds;
|
rstl::reserved_vector<TUniqueId, 16> wpIds;
|
||||||
GatherWaypoints(wp, mgr, wpIds);
|
GatherWaypoints(wp, mgr, wpIds);
|
||||||
for (const auto& id : wpIds)
|
for (const auto& id : wpIds)
|
||||||
x570_waypoints.push_back(id);
|
x574_waypoints.push_back(id);
|
||||||
} else if (CPatterned* p = CPatterned::CastTo<CThardusRockProjectile>(mgr.ObjectById(connId))) {
|
} else if (CPatterned* p = CPatterned::CastTo<CThardusRockProjectile>(mgr.ObjectById(connId))) {
|
||||||
x5fc_projectileId = connId;
|
x5fc_projectileId = connId;
|
||||||
x60c_projectileEditorId = conn.x8_objId;
|
x60c_projectileEditorId = conn.x8_objId;
|
||||||
|
@ -436,7 +441,7 @@ void CThardus::PreRender(CStateManager& mgr, const zeus::CFrustum& frustum) {
|
||||||
void CThardus::Render(const CStateManager& mgr) const {
|
void CThardus::Render(const CStateManager& mgr) const {
|
||||||
CPatterned::Render(mgr);
|
CPatterned::Render(mgr);
|
||||||
if (mgr.GetPlayerState()->GetActiveVisor(mgr) == CPlayerState::EPlayerVisor::Thermal && x7c4_ != 0) {
|
if (mgr.GetPlayerState()->GetActiveVisor(mgr) == CPlayerState::EPlayerVisor::Thermal && x7c4_ != 0) {
|
||||||
// sub801e32a0(mgr, x7c0_);
|
RenderFlare(mgr, x7c0_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void CThardus::Touch(CActor& act, CStateManager& mgr) { CPatterned::Touch(act, mgr); }
|
void CThardus::Touch(CActor& act, CStateManager& mgr) { CPatterned::Touch(act, mgr); }
|
||||||
|
@ -476,7 +481,19 @@ void CThardus::Dead(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
}
|
}
|
||||||
CPatterned::Dead(mgr, msg, arg);
|
CPatterned::Dead(mgr, msg, arg);
|
||||||
}
|
}
|
||||||
void CThardus::PathFind(CStateManager& mgr, EStateMsg msg, float arg) { CPatterned::PathFind(mgr, msg, arg); }
|
void CThardus::PathFind(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
CPatterned::PathFind(mgr, msg, arg);
|
||||||
|
return;
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
x2e0_destPos = sub801de550(mgr);
|
||||||
|
x7e4_ = x7d8_ = x2e0_destPos;
|
||||||
|
CPatterned::PathFind(mgr, EStateMsg::Activate, arg);
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
|
||||||
|
} else if (msg == EStateMsg::Deactivate) {
|
||||||
|
x8d4_ = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
void CThardus::TargetPatrol(CStateManager& mgr, EStateMsg msg, float arg) {
|
void CThardus::TargetPatrol(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
if (msg == EStateMsg::Activate) {
|
if (msg == EStateMsg::Activate) {
|
||||||
x5ec_ = 0;
|
x5ec_ = 0;
|
||||||
|
@ -514,10 +531,31 @@ void CThardus::Generate(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
x93d_ = false;
|
x93d_ = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void CThardus::Attack(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Attack(mgr, msg, arg); }
|
void CThardus::Attack(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
x5ec_ = 0;
|
||||||
|
++x570_;
|
||||||
|
x5ec_ = 0;
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
if (x5ec_ == 0) {
|
||||||
|
if (GetBodyController()->GetCurrentStateId() != pas::EAnimationState::MeleeAttack) {
|
||||||
|
if (mgr.GetActiveRandom()->Float() <= 0.5f) {
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(CBCMeleeAttackCmd(pas::ESeverity::One));
|
||||||
|
} else {
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(CBCMeleeAttackCmd(pas::ESeverity::Zero));
|
||||||
|
}
|
||||||
|
++x570_;
|
||||||
|
} else {
|
||||||
|
x5ec_ = 2;
|
||||||
|
}
|
||||||
|
} else if (x5ec_ == 2 && GetBodyController()->GetCurrentStateId() != pas::EAnimationState::MeleeAttack) {
|
||||||
|
x5ec_ = 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
void CThardus::LoopedAttack(CStateManager& mgr, EStateMsg msg, float arg) { CAi::LoopedAttack(mgr, msg, arg); }
|
void CThardus::LoopedAttack(CStateManager& mgr, EStateMsg msg, float arg) { CAi::LoopedAttack(mgr, msg, arg); }
|
||||||
void CThardus::DoubleSnap(CStateManager& mgr, EStateMsg msg, float arg) { CAi::DoubleSnap(mgr, msg, arg); }
|
void CThardus::DoubleSnap(CStateManager& mgr, EStateMsg msg, float arg) { }
|
||||||
void CThardus::Shuffle(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Shuffle(mgr, msg, arg); }
|
void CThardus::Shuffle(CStateManager& mgr, EStateMsg msg, float arg) { }
|
||||||
void CThardus::GetUp(CStateManager& mgr, EStateMsg msg, float arg) {
|
void CThardus::GetUp(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
if (msg != EStateMsg::Activate)
|
if (msg != EStateMsg::Activate)
|
||||||
return;
|
return;
|
||||||
|
@ -539,21 +577,207 @@ void CThardus::Taunt(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CThardus::Suck(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Suck(mgr, msg, arg); }
|
void CThardus::Suck(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
void CThardus::ProjectileAttack(CStateManager& mgr, EStateMsg msg, float arg) { CAi::ProjectileAttack(mgr, msg, arg); }
|
if (msg == EStateMsg::Activate) {
|
||||||
void CThardus::Flinch(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Flinch(mgr, msg, arg); }
|
x909_ = true;
|
||||||
void CThardus::TelegraphAttack(CStateManager& mgr, EStateMsg msg, float arg) { CAi::TelegraphAttack(mgr, msg, arg); }
|
x93d_ = true;
|
||||||
void CThardus::Explode(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Explode(mgr, msg, arg); }
|
SendScriptMsgs(EScriptObjectState::MaxReached, mgr, EScriptObjectMessage::None);
|
||||||
void CThardus::Cover(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Cover(mgr, msg, arg); }
|
} else if (msg == EStateMsg::Deactivate) {
|
||||||
void CThardus::Enraged(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Enraged(mgr, msg, arg); }
|
x689_ = true;
|
||||||
void CThardus::Growth(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Growth(mgr, msg, arg); }
|
}
|
||||||
void CThardus::Faint(CStateManager& mgr, EStateMsg msg, float arg) { CAi::Faint(mgr, msg, arg); }
|
}
|
||||||
|
void CThardus::ProjectileAttack(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
x5ec_ = 0;
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
if (x5ec_ == 1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (x5ec_ == 0) {
|
||||||
|
if (GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::ProjectileAttack) {
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(CBCProjectileAttackCmd(pas::ESeverity::Zero, {}, false));
|
||||||
|
x5ec_ = 0;
|
||||||
|
} else {
|
||||||
|
x5ec_ = 2;
|
||||||
|
}
|
||||||
|
} else if (x5ec_ == 2 &&
|
||||||
|
GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::ProjectileAttack) {
|
||||||
|
x5ec_ = 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void CThardus::Flinch(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
for (TUniqueId uid : x798_) {
|
||||||
|
if (CThardusRockProjectile* rock = CPatterned::CastTo<CThardusRockProjectile>(mgr.ObjectById(uid)))
|
||||||
|
rock->sub80203d58();
|
||||||
|
}
|
||||||
|
x93b_ = true;
|
||||||
|
x93d_ = true;
|
||||||
|
x909_ = true;
|
||||||
|
x93c_ = false;
|
||||||
|
SetState(-1, mgr);
|
||||||
|
x94d_ = true;
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
pas::ESeverity severity = pas::ESeverity::Invalid;
|
||||||
|
switch (x648_currentRock) {
|
||||||
|
case 1:
|
||||||
|
severity = pas::ESeverity::Zero;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
severity = pas::ESeverity::One;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
severity = pas::ESeverity::Two;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
severity = pas::ESeverity::Three;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
severity = pas::ESeverity::Four;
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
severity = pas::ESeverity::Five;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (x5ec_ == 0) {
|
||||||
|
if (GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::KnockBack)
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(CBCKnockBackCmd({}, severity));
|
||||||
|
else
|
||||||
|
x5ec_ = 2;
|
||||||
|
} else if (x5ec_ == 2 &&
|
||||||
|
GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::KnockBack) {
|
||||||
|
x5ec_ = 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void CThardus::TelegraphAttack(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
x5ec_ = 0;
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
if (x5ec_ == 0) {
|
||||||
|
if (GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::ProjectileAttack) {
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(CBCProjectileAttackCmd(pas::ESeverity::One, {}, false));
|
||||||
|
x5ec_ = 0;
|
||||||
|
} else
|
||||||
|
x5ec_ = 2;
|
||||||
|
} else if (x5ec_ == 2 &&
|
||||||
|
GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::ProjectileAttack) {
|
||||||
|
x5ec_ = 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void CThardus::Explode(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
x5ec_ = 0;
|
||||||
|
CSfxManager::SfxStop(x904_);
|
||||||
|
x909_ = true;
|
||||||
|
x93d_ = true;
|
||||||
|
x909_ = true;
|
||||||
|
SendScriptMsgs(EScriptObjectState::Arrived, mgr, EScriptObjectMessage::None);
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
if (x5ec_ == 0) {
|
||||||
|
if (GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::Step) {
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(
|
||||||
|
CBCStepCmd(pas::EStepDirection::Forward, pas::EStepType::Dodge));
|
||||||
|
} else {
|
||||||
|
x5ec_ = 2;
|
||||||
|
}
|
||||||
|
} else if (x5ec_ == 2 &&
|
||||||
|
GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::Step) {
|
||||||
|
x5ec_ = 3;
|
||||||
|
}
|
||||||
|
} else if (msg == EStateMsg::Deactivate) {
|
||||||
|
x8f0_ = true;
|
||||||
|
x909_ = false;
|
||||||
|
x93d_ = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void CThardus::Cover(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
SetState(1, mgr);
|
||||||
|
x93d_ = false;
|
||||||
|
x909_ = false;
|
||||||
|
if (x610_destroyableRocks.size() - 2 <= x648_currentRock)
|
||||||
|
x690_ = 1.1f;
|
||||||
|
AddMaterial(EMaterialTypes::RadarObject, mgr);
|
||||||
|
} else if (msg == EStateMsg::Deactivate) {
|
||||||
|
x690_ = 1.f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void CThardus::Enraged(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
x5ec_ = 0;
|
||||||
|
x688_ = true;
|
||||||
|
x908_ = true;
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
if (x5ec_ == 0) {
|
||||||
|
if (GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::Taunt) {
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(CBCTauntCmd(pas::ETauntType::Zero));
|
||||||
|
} else {
|
||||||
|
x5ec_ = 2;
|
||||||
|
}
|
||||||
|
} else if (x5ec_ == 2 &&
|
||||||
|
GetBodyController()->GetBodyStateInfo().GetCurrentStateId() != pas::EAnimationState::Taunt) {
|
||||||
|
x5ec_ = 3;
|
||||||
|
}
|
||||||
|
} else if (msg == EStateMsg::Deactivate) {
|
||||||
|
x908_ = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void CThardus::Growth(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
x5ec_ = 0;
|
||||||
|
x904_ = CSfxManager::SfxStart(SFXsfx07AD, 1.f, 0.f, false, 0x7f, true, GetAreaIdAlways());
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
if (x5ec_ == 0) {
|
||||||
|
if (GetBodyController()->GetCurrentStateId() != pas::EAnimationState::Step) {
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(
|
||||||
|
CBCStepCmd(pas::EStepDirection::Forward, pas::EStepType::BreakDodge));
|
||||||
|
} else {
|
||||||
|
x5ec_ = 2;
|
||||||
|
}
|
||||||
|
} else if (x5ec_ == 2 && GetBodyController()->GetCurrentStateId() != pas::EAnimationState::Step) {
|
||||||
|
x5ec_ = 3;
|
||||||
|
}
|
||||||
|
} else if (msg == EStateMsg::Deactivate) {
|
||||||
|
if (TCastToPtr<CScriptDistanceFog> fog = mgr.ObjectById(x64c_fog)) {
|
||||||
|
mgr.SendScriptMsg(GetUniqueId(), mgr.GetEditorIdForUniqueId(fog->GetUniqueId()), EScriptObjectMessage::Activate,
|
||||||
|
EScriptObjectState::Any);
|
||||||
|
SendScriptMsgs(EScriptObjectState::Play, mgr, EScriptObjectMessage::None);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void CThardus::Faint(CStateManager& mgr, EStateMsg msg, float arg) {
|
||||||
|
if (msg == EStateMsg::Activate) {
|
||||||
|
x5ec_ = 0;
|
||||||
|
x93c_ = false;
|
||||||
|
SetState(-1, mgr);
|
||||||
|
for (TUniqueId uid : x798_) {
|
||||||
|
if (CThardusRockProjectile* rock = CPatterned::CastTo<CThardusRockProjectile>(mgr.ObjectById(uid)))
|
||||||
|
rock->sub80203d58();
|
||||||
|
}
|
||||||
|
x94d_ = true;
|
||||||
|
} else if (msg == EStateMsg::Update) {
|
||||||
|
if (x5ec_ == 0) {
|
||||||
|
if (GetBodyController()->GetCurrentStateId() != pas::EAnimationState::KnockBack) {
|
||||||
|
GetBodyController()->GetCommandMgr().DeliverCmd(CBCKnockBackCmd({}, pas::ESeverity::Six));
|
||||||
|
} else {
|
||||||
|
x5ec_ = 2;
|
||||||
|
}
|
||||||
|
} else if (x5ec_ == 2 && GetBodyController()->GetCurrentStateId() != pas::EAnimationState::KnockBack) {
|
||||||
|
x5ec_ = 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool CThardus::PathFound(CStateManager& mgr, float arg) { return x8d4_; }
|
bool CThardus::PathFound(CStateManager& mgr, float arg) { return x8d4_; }
|
||||||
bool CThardus::InRange(CStateManager& mgr, float arg) {
|
bool CThardus::InRange(CStateManager& mgr, float arg) {
|
||||||
return (mgr.GetPlayer().GetTranslation().toVec2f() - GetTranslation().toVec2f()).magnitude() <
|
return (mgr.GetPlayer().GetTranslation().toVec2f() - GetTranslation().toVec2f()).magnitude() <
|
||||||
10.f * GetModelData()->GetScale().x();
|
10.f * GetModelData()->GetScale().x();
|
||||||
}
|
}
|
||||||
bool CThardus::PatternOver(CStateManager& mgr, float arg) { return !x570_waypoints.empty() || x93b_; }
|
bool CThardus::PatternOver(CStateManager& mgr, float arg) { return !x574_waypoints.empty() || x93b_; }
|
||||||
bool CThardus::AnimOver(CStateManager& mgr, float arg) { return x5ec_ == 3; }
|
bool CThardus::AnimOver(CStateManager& mgr, float arg) { return x5ec_ == 3; }
|
||||||
bool CThardus::InPosition(CStateManager& mgr, float arg) { return CPatterned::InPosition(mgr, arg); }
|
bool CThardus::InPosition(CStateManager& mgr, float arg) { return CPatterned::InPosition(mgr, arg); }
|
||||||
bool CThardus::ShouldTurn(CStateManager& mgr, float arg) { return CAi::ShouldTurn(mgr, arg); }
|
bool CThardus::ShouldTurn(CStateManager& mgr, float arg) { return CAi::ShouldTurn(mgr, arg); }
|
||||||
|
@ -624,7 +848,7 @@ void CThardus::_SetupCollisionManagers(CStateManager& mgr) {
|
||||||
_SetupCollisionActorMaterials(x5f8_, mgr);
|
_SetupCollisionActorMaterials(x5f8_, mgr);
|
||||||
list.clear();
|
list.clear();
|
||||||
x634_nonDestroyableActors.reserve(x5f4_->GetNumCollisionActors() + x5f0_rockColliders->GetNumCollisionActors() +
|
x634_nonDestroyableActors.reserve(x5f4_->GetNumCollisionActors() + x5f0_rockColliders->GetNumCollisionActors() +
|
||||||
x5f8_->GetNumCollisionActors());
|
x5f8_->GetNumCollisionActors());
|
||||||
sub801dd4fc(x5f4_);
|
sub801dd4fc(x5f4_);
|
||||||
sub801dd4fc(x5f8_);
|
sub801dd4fc(x5f8_);
|
||||||
for (size_t i = 0; i < x5f0_rockColliders->GetNumCollisionActors(); ++i) {
|
for (size_t i = 0; i < x5f0_rockColliders->GetNumCollisionActors(); ++i) {
|
||||||
|
@ -718,7 +942,8 @@ void CThardus::sub801dbbdc(CStateManager& mgr, CDestroyableRock* rock) {
|
||||||
x92c_currentRockPos = rock->GetTranslation();
|
x92c_currentRockPos = rock->GetTranslation();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CThardus::UpdateNonDestroyableCollisionActorMaterials(EUpdateMaterialMode mode, EMaterialTypes mat, urde::CStateManager& mgr) {
|
void CThardus::UpdateNonDestroyableCollisionActorMaterials(EUpdateMaterialMode mode, EMaterialTypes mat,
|
||||||
|
urde::CStateManager& mgr) {
|
||||||
for (const auto& uid : x634_nonDestroyableActors) {
|
for (const auto& uid : x634_nonDestroyableActors) {
|
||||||
if (TCastToPtr<CCollisionActor> col = mgr.ObjectById(uid)) {
|
if (TCastToPtr<CCollisionActor> col = mgr.ObjectById(uid)) {
|
||||||
if (mode == EUpdateMaterialMode::Remove)
|
if (mode == EUpdateMaterialMode::Remove)
|
||||||
|
@ -731,8 +956,8 @@ void CThardus::UpdateNonDestroyableCollisionActorMaterials(EUpdateMaterialMode m
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CThardus::UpdateExcludeList(const std::unique_ptr<CCollisionActorManager>& colMgr, EUpdateMaterialMode mode, EMaterialTypes w2,
|
void CThardus::UpdateExcludeList(const std::unique_ptr<CCollisionActorManager>& colMgr, EUpdateMaterialMode mode,
|
||||||
CStateManager& mgr) {
|
EMaterialTypes w2, CStateManager& mgr) {
|
||||||
for (size_t i = 0; i < colMgr->GetNumCollisionActors(); ++i) {
|
for (size_t i = 0; i < colMgr->GetNumCollisionActors(); ++i) {
|
||||||
if (TCastToPtr<CActor> colAct = mgr.ObjectById(colMgr->GetCollisionDescFromIndex(i).GetCollisionActorId())) {
|
if (TCastToPtr<CActor> colAct = mgr.ObjectById(colMgr->GetCollisionDescFromIndex(i).GetCollisionActorId())) {
|
||||||
CMaterialList exclude = colAct->GetMaterialFilter().GetExcludeList();
|
CMaterialList exclude = colAct->GetMaterialFilter().GetExcludeList();
|
||||||
|
@ -746,4 +971,51 @@ void CThardus::UpdateExcludeList(const std::unique_ptr<CCollisionActorManager>&
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CThardus::RenderFlare(const CStateManager& mgr, float t) const {
|
||||||
|
if (!x91c_flareTexture)
|
||||||
|
return;
|
||||||
|
if (!m_flareFilter)
|
||||||
|
m_flareFilter.emplace(EFilterType::Add, x91c_flareTexture);
|
||||||
|
|
||||||
|
const float scale = 30.f * t;
|
||||||
|
zeus::CVector3f offset = scale * CGraphics::g_ViewMatrix.basis[2];
|
||||||
|
zeus::CVector3f max = x92c_currentRockPos + (scale * CGraphics::g_ViewMatrix.basis[0]);
|
||||||
|
zeus::CVector3f min = x92c_currentRockPos - (scale * CGraphics::g_ViewMatrix.basis[0]);
|
||||||
|
CGraphics::SetModelMatrix(zeus::CTransform());
|
||||||
|
const std::array<CTexturedQuadFilter::Vert, 4> verts{{
|
||||||
|
{{max.x() + offset.x(), max.y() + offset.y(), max.z() + offset.z()}, {0.f, 1.f}},
|
||||||
|
{{min.x() + offset.x(), min.y() + offset.y(), min.z() + offset.z()}, {0.f, 0.f}},
|
||||||
|
{{max.x() - offset.x(), max.y() - offset.y(), max.z() - offset.z()}, {1.f, 1.f}},
|
||||||
|
{{min.x() - offset.x(), min.y() - offset.y(), min.z() - offset.z()}, {1.f, 0.f}},
|
||||||
|
}};
|
||||||
|
|
||||||
|
m_flareFilter->drawVerts({t, t}, verts.data());
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
CGraphics::SetModelMatrix(zeus::CTransform());
|
||||||
|
CGraphics::SetBlendMode(ERglBlendMode::Blend, ERglBlendFactor::One, ERglBlendFactor::One, ERglLogicOp::Clear);
|
||||||
|
CGraphics::SetTevOp(0, CGraphics::sTevPass805a5ebc);
|
||||||
|
CGraphics::SetTevOp(1, CGraphics::sTevPass805a564c);
|
||||||
|
CGraphics::SetDepthWriteMode(false, ERglEnum::Always, false);
|
||||||
|
CGraphics::StreamColor(zeus::CColor(f1, f1));
|
||||||
|
CGraphics::StreamBegin(0xa0);
|
||||||
|
CGraphics::StreamTexCoord(0.f, 0.f);
|
||||||
|
CGraphics::StreamVertex(min + offset);
|
||||||
|
CGraphics::StreamTexCoord(1.f, 0.f);
|
||||||
|
CGraphics::StreamVertex(min - offset);
|
||||||
|
CGraphics::StreamTexCoord(1.f, 1.f);
|
||||||
|
CGraphics::StreamVertex(max - offset);
|
||||||
|
CGraphics::StreamTexCoord(0.f, 1.f);
|
||||||
|
CGraphics::StreamVertex(max + offset);
|
||||||
|
CGraphics::StreamEnd();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
zeus::CVector3f CThardus::sub801de550(const CStateManager& mgr) const {
|
||||||
|
if (x570_)
|
||||||
|
return {};
|
||||||
|
|
||||||
|
return {};
|
||||||
|
}
|
||||||
} // namespace urde::MP1
|
} // namespace urde::MP1
|
|
@ -21,7 +21,8 @@ class CThardus : public CPatterned {
|
||||||
};
|
};
|
||||||
u32 x568_;
|
u32 x568_;
|
||||||
TUniqueId x56c_ = kInvalidUniqueId;
|
TUniqueId x56c_ = kInvalidUniqueId;
|
||||||
std::vector<TUniqueId> x570_waypoints;
|
u32 x570_ = 0;
|
||||||
|
std::vector<TUniqueId> x574_waypoints;
|
||||||
u32 x5c4_ = 1;
|
u32 x5c4_ = 1;
|
||||||
bool x5c8_heardPlayer = false;
|
bool x5c8_heardPlayer = false;
|
||||||
/* NOTE(phil) These two vectors used to vectors of CModelData, They have been converted to vectors of CStaticRes due
|
/* NOTE(phil) These two vectors used to vectors of CModelData, They have been converted to vectors of CStaticRes due
|
||||||
|
@ -85,7 +86,7 @@ class CThardus : public CPatterned {
|
||||||
std::vector<TUniqueId> x7a8_timers;
|
std::vector<TUniqueId> x7a8_timers;
|
||||||
float x7b8_ = 0.f;
|
float x7b8_ = 0.f;
|
||||||
float x7bc_ = 10.f;
|
float x7bc_ = 10.f;
|
||||||
u32 x7c0_;
|
float x7c0_ = 1.0f;
|
||||||
u32 x7c4_ = 0;
|
u32 x7c4_ = 0;
|
||||||
bool x7c8_ = false;
|
bool x7c8_ = false;
|
||||||
zeus::CVector3f x7cc_;
|
zeus::CVector3f x7cc_;
|
||||||
|
@ -97,11 +98,11 @@ class CThardus : public CPatterned {
|
||||||
zeus::CVector3f x8e4_;
|
zeus::CVector3f x8e4_;
|
||||||
bool x8f0_ = false;
|
bool x8f0_ = false;
|
||||||
std::vector<TUniqueId> x8f4_waypoints;
|
std::vector<TUniqueId> x8f4_waypoints;
|
||||||
u32 x904_ = 0;
|
CSfxHandle x904_ = 0;
|
||||||
bool x908_ = false;
|
bool x908_ = false;
|
||||||
bool x909_ = false;
|
bool x909_ = false;
|
||||||
std::vector<float> x90c_;
|
std::vector<float> x90c_;
|
||||||
TLockedToken<CTexture> x91c_;
|
TLockedToken<CTexture> x91c_flareTexture;
|
||||||
TUniqueId x928_currentRockId;
|
TUniqueId x928_currentRockId;
|
||||||
zeus::CVector3f x92c_currentRockPos;
|
zeus::CVector3f x92c_currentRockPos;
|
||||||
bool x938_ = false;
|
bool x938_ = false;
|
||||||
|
@ -138,7 +139,7 @@ class CThardus : public CPatterned {
|
||||||
void sub801dd608(CStateManager& mgr);
|
void sub801dd608(CStateManager& mgr);
|
||||||
void sub801dcfa4(CStateManager& mgr);
|
void sub801dcfa4(CStateManager& mgr);
|
||||||
void sub80deadc(CStateManager& mgr) {
|
void sub80deadc(CStateManager& mgr) {
|
||||||
if (x570_waypoints.empty()) {
|
if (x574_waypoints.empty()) {
|
||||||
sub801de9f8(mgr);
|
sub801de9f8(mgr);
|
||||||
} else {
|
} else {
|
||||||
if (sub801dc2c8() || x5c4_ != 0 || x944_ <= 0.f)
|
if (sub801dc2c8() || x5c4_ != 0 || x944_ <= 0.f)
|
||||||
|
@ -158,6 +159,11 @@ class CThardus : public CPatterned {
|
||||||
void _SetupCollisionManagers(CStateManager& mgr);
|
void _SetupCollisionManagers(CStateManager& mgr);
|
||||||
void _BuildSphereJointList(const SSphereJointInfo* arr, int count, std::vector<CJointCollisionDescription>& list);
|
void _BuildSphereJointList(const SSphereJointInfo* arr, int count, std::vector<CJointCollisionDescription>& list);
|
||||||
void _BuildAABoxJointList(const SAABoxJointInfo* arr, int count, std::vector<CJointCollisionDescription>& list);
|
void _BuildAABoxJointList(const SAABoxJointInfo* arr, int count, std::vector<CJointCollisionDescription>& list);
|
||||||
|
void RenderFlare(const CStateManager& mgr, float t) const;
|
||||||
|
zeus::CVector3f sub801de550(const CStateManager& mgr) const;
|
||||||
|
zeus::CVector3f sub801de434(const CStateManager& mgr) const { return {}; }
|
||||||
|
|
||||||
|
mutable std::optional<CTexturedQuadFilter> m_flareFilter;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
DEFINE_PATTERNED(Thardus)
|
DEFINE_PATTERNED(Thardus)
|
||||||
|
@ -214,7 +220,7 @@ public:
|
||||||
bool AggressionCheck(CStateManager& mgr, float arg) override { return x330_stateMachineState.GetTime() > 0.1f; }
|
bool AggressionCheck(CStateManager& mgr, float arg) override { return x330_stateMachineState.GetTime() > 0.1f; }
|
||||||
bool AttackOver(CStateManager& mgr, float arg) override { return true; }
|
bool AttackOver(CStateManager& mgr, float arg) override { return true; }
|
||||||
bool ShouldTaunt(CStateManager& mgr, float arg) override { return false; }
|
bool ShouldTaunt(CStateManager& mgr, float arg) override { return false; }
|
||||||
bool ShouldMove(CStateManager& mgr, float arg) override { return x68c_ < x570_waypoints.size() || x93b_; }
|
bool ShouldMove(CStateManager& mgr, float arg) override { return x68c_ < x574_waypoints.size() || x93b_; }
|
||||||
bool CodeTrigger(CStateManager& mgr, float arg) override { return x95c_doCodeTrigger; }
|
bool CodeTrigger(CStateManager& mgr, float arg) override { return x95c_doCodeTrigger; }
|
||||||
bool IsDizzy(CStateManager& mgr, float arg) override { return x330_stateMachineState.GetTime() > 4.f; }
|
bool IsDizzy(CStateManager& mgr, float arg) override { return x330_stateMachineState.GetTime() > 4.f; }
|
||||||
bool ShouldCallForBackup(CStateManager& mgr, float arg) override { return x330_stateMachineState.GetTime() > .5f; }
|
bool ShouldCallForBackup(CStateManager& mgr, float arg) override { return x330_stateMachineState.GetTime() > .5f; }
|
||||||
|
|
|
@ -1,13 +1,14 @@
|
||||||
#include "Runtime/MP1/World/CThardusRockProjectile.hpp"
|
#include "Runtime/MP1/World/CThardusRockProjectile.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde::MP1 {
|
||||||
|
|
||||||
CThardusRockProjectile::CThardusRockProjectile(TUniqueId uid, std::string_view name, const CEntityInfo& info,
|
CThardusRockProjectile::CThardusRockProjectile(TUniqueId uid, std::string_view name, const CEntityInfo& info,
|
||||||
const zeus::CTransform& xf, CModelData&& modelData,
|
const zeus::CTransform& xf, CModelData&& modelData,
|
||||||
const CActorParameters& aParms, const CPatternedInfo& patternedInfo,
|
const CActorParameters& aParms, const CPatternedInfo& patternedInfo,
|
||||||
const std::vector<CModelData>& mDataVec, u32)
|
std::vector<std::unique_ptr<CModelData>>&& mDataVec,
|
||||||
|
CAssetId stateMachine, float)
|
||||||
: CPatterned(ECharacter::ThardusRockProjectile, uid, name, EFlavorType::Zero, info, xf, std::move(modelData),
|
: CPatterned(ECharacter::ThardusRockProjectile, uid, name, EFlavorType::Zero, info, xf, std::move(modelData),
|
||||||
patternedInfo, EMovementType::Flyer, EColliderType::One, EBodyType::Flyer, aParms,
|
patternedInfo, EMovementType::Flyer, EColliderType::One, EBodyType::Flyer, aParms,
|
||||||
EKnockBackVariant::Medium) {}
|
EKnockBackVariant::Medium)
|
||||||
|
, x57c_(std::move(mDataVec)) {}
|
||||||
|
|
||||||
} // namespace urde
|
} // namespace urde::MP1
|
||||||
|
|
|
@ -2,14 +2,27 @@
|
||||||
|
|
||||||
#include "Runtime/World/CPatterned.hpp"
|
#include "Runtime/World/CPatterned.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde::MP1 {
|
||||||
|
|
||||||
class CThardusRockProjectile : public CPatterned {
|
class CThardusRockProjectile : public CPatterned {
|
||||||
|
float x568_;
|
||||||
|
u32 x56c_ = 0;
|
||||||
|
TUniqueId x570_ = kInvalidUniqueId;
|
||||||
|
bool x572_ = false;
|
||||||
|
s32 x574_ = -1;
|
||||||
|
s32 x578_ = 0;
|
||||||
|
std::vector<std::unique_ptr<CModelData>> x57c_;
|
||||||
|
u32 x590_ = 0;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
DEFINE_PATTERNED(ThardusRockProjectile)
|
DEFINE_PATTERNED(ThardusRockProjectile)
|
||||||
CThardusRockProjectile(TUniqueId uid, std::string_view name, const CEntityInfo& info, const zeus::CTransform& xf,
|
CThardusRockProjectile(TUniqueId uid, std::string_view name, const CEntityInfo& info, const zeus::CTransform& xf,
|
||||||
CModelData&& modelData, const CActorParameters& aParms, const CPatternedInfo& patternedInfo,
|
CModelData&& modelData, const CActorParameters& aParms, const CPatternedInfo& patternedInfo,
|
||||||
const std::vector<CModelData>& mDataVec, u32);
|
std::vector<std::unique_ptr<CModelData>>&& mDataVec, CAssetId, float);
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace urde
|
void sub80203d58() {
|
||||||
|
x328_25_verticalMovement = false;
|
||||||
|
x150_momentum = {0.f, 0.f, 2.f * -GetWeight()};
|
||||||
|
x56c_ = 3;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} // namespace urde::MP1
|
||||||
|
|
|
@ -32,7 +32,7 @@ void CDestroyableRock::PreRender(CStateManager& mgr, const zeus::CFrustum& frust
|
||||||
xb4_drawFlags = CModelFlags(0, 0, 3, zeus::skWhite);
|
xb4_drawFlags = CModelFlags(0, 0, 3, zeus::skWhite);
|
||||||
} else {
|
} else {
|
||||||
x330_.a() = 1.f;
|
x330_.a() = 1.f;
|
||||||
xb4_drawFlags = CModelFlags(0, 0, 3, x330_);
|
xb4_drawFlags = CModelFlags(2, 0, 3, x330_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3659,7 +3659,7 @@ void CPlayer::SetOrbitTargetId(TUniqueId id, CStateManager& mgr) {
|
||||||
if (id != kInvalidUniqueId) {
|
if (id != kInvalidUniqueId) {
|
||||||
x394_orbitingEnemy =
|
x394_orbitingEnemy =
|
||||||
(TCastToPtr<CPatterned>(mgr.ObjectById(id)) || TCastToPtr<CWallCrawlerSwarm>(mgr.ObjectById(id)) ||
|
(TCastToPtr<CPatterned>(mgr.ObjectById(id)) || TCastToPtr<CWallCrawlerSwarm>(mgr.ObjectById(id)) ||
|
||||||
CPatterned::CastTo<CThardusRockProjectile>(mgr.ObjectById(id)) ||
|
CPatterned::CastTo<MP1::CThardusRockProjectile>(mgr.ObjectById(id)) ||
|
||||||
TCastToPtr<CScriptGunTurret>(mgr.ObjectById(id)));
|
TCastToPtr<CScriptGunTurret>(mgr.ObjectById(id)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -41,6 +41,7 @@
|
||||||
#include "Runtime/MP1/World/CSpacePirate.hpp"
|
#include "Runtime/MP1/World/CSpacePirate.hpp"
|
||||||
#include "Runtime/MP1/World/CSpankWeed.hpp"
|
#include "Runtime/MP1/World/CSpankWeed.hpp"
|
||||||
#include "Runtime/MP1/World/CThardus.hpp"
|
#include "Runtime/MP1/World/CThardus.hpp"
|
||||||
|
#include "Runtime/MP1/World/CThardusRockProjectile.hpp"
|
||||||
#include "Runtime/MP1/World/CTryclops.hpp"
|
#include "Runtime/MP1/World/CTryclops.hpp"
|
||||||
#include "Runtime/MP1/World/CWarWasp.hpp"
|
#include "Runtime/MP1/World/CWarWasp.hpp"
|
||||||
#include "Runtime/Particle/CWeaponDescription.hpp"
|
#include "Runtime/Particle/CWeaponDescription.hpp"
|
||||||
|
@ -2738,7 +2739,31 @@ CEntity* ScriptLoader::LoadColorModulate(CStateManager& mgr, CInputStream& in, i
|
||||||
|
|
||||||
CEntity* ScriptLoader::LoadThardusRockProjectile(CStateManager& mgr, CInputStream& in, int propCount,
|
CEntity* ScriptLoader::LoadThardusRockProjectile(CStateManager& mgr, CInputStream& in, int propCount,
|
||||||
const CEntityInfo& info) {
|
const CEntityInfo& info) {
|
||||||
return nullptr;
|
if (!EnsurePropertyCount(propCount, 3, "ThardusRockProjectile"))
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
SScaledActorHead actorHead = LoadScaledActorHead(in, mgr);
|
||||||
|
auto [pInfoValid, pInfoCount] = CPatternedInfo::HasCorrectParameterCount(in);
|
||||||
|
if (!pInfoValid)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
CPatternedInfo pInfo(in, pInfoCount);
|
||||||
|
CActorParameters actParms = LoadActorParameters(in);
|
||||||
|
in.readBool();
|
||||||
|
in.readBool();
|
||||||
|
float f1 = in.readFloatBig();
|
||||||
|
CAssetId modelId(in);
|
||||||
|
CAssetId stateMachine(in);
|
||||||
|
if (!pInfo.GetAnimationParameters().GetACSFile().IsValid())
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
std::vector<std::unique_ptr<CModelData>> mDataVec;
|
||||||
|
CModelData mData(CAnimRes(pInfo.GetAnimationParameters().GetACSFile(), 0, actorHead.x40_scale,
|
||||||
|
pInfo.GetAnimationParameters().GetInitialAnimation(), true));
|
||||||
|
mDataVec.reserve(3);
|
||||||
|
mDataVec.emplace_back(std::make_unique<CModelData>(CStaticRes(modelId, zeus::skOne3f)));
|
||||||
|
return new MP1::CThardusRockProjectile(mgr.AllocateUniqueId(), actorHead.x0_name, info, actorHead.x10_transform,
|
||||||
|
std::move(mData), actParms, pInfo, std::move(mDataVec), stateMachine, f1);
|
||||||
}
|
}
|
||||||
|
|
||||||
CEntity* ScriptLoader::LoadMidi(CStateManager& mgr, CInputStream& in, int propCount, const CEntityInfo& info) {
|
CEntity* ScriptLoader::LoadMidi(CStateManager& mgr, CInputStream& in, int propCount, const CEntityInfo& info) {
|
||||||
|
|
Loading…
Reference in New Issue