mirror of https://github.com/AxioDL/metaforce.git
Merge branch 'master' into omegapirate
# Conflicts: # Runtime/GuiSys/CAuiImagePane.cpp
This commit is contained in:
commit
32c44cbf05
|
@ -8,6 +8,7 @@
|
||||||
|
|
||||||
#include "Runtime/rstl.hpp"
|
#include "Runtime/rstl.hpp"
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
|
#include "Runtime/AutoMapper/CMapUniverse.hpp"
|
||||||
#include "Runtime/MP1/CInGameGuiManager.hpp"
|
#include "Runtime/MP1/CInGameGuiManager.hpp"
|
||||||
|
|
||||||
#include <zeus/CQuaternion.hpp>
|
#include <zeus/CQuaternion.hpp>
|
||||||
|
@ -17,7 +18,6 @@
|
||||||
#include <zeus/CVector3f.hpp>
|
#include <zeus/CVector3f.hpp>
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CMapUniverse;
|
|
||||||
class CMapWorldInfo;
|
class CMapWorldInfo;
|
||||||
class CStateManager;
|
class CStateManager;
|
||||||
class IWorld;
|
class IWorld;
|
||||||
|
|
|
@ -1377,7 +1377,11 @@ std::pair<TEditorId, TUniqueId> CStateManager::LoadScriptObject(TAreaId aid, ESc
|
||||||
in.readByte();
|
in.readByte();
|
||||||
|
|
||||||
if (error || ent == nullptr) {
|
if (error || ent == nullptr) {
|
||||||
LogModule.report(logvisor::Error, FMT_STRING("Script load error while loading {}"), ScriptObjectTypeToStr(type));
|
in.seek(startPos, athena::SeekOrigin::Begin);
|
||||||
|
std::string name = HashInstanceName(in);
|
||||||
|
in.seek(startPos + length, athena::SeekOrigin::Begin);
|
||||||
|
LogModule.report(logvisor::Error, FMT_STRING("Script load error while loading {}, name: {}"),
|
||||||
|
ScriptObjectTypeToStr(type), name);
|
||||||
return {kInvalidEditorId, kInvalidUniqueId};
|
return {kInvalidEditorId, kInvalidUniqueId};
|
||||||
} else {
|
} else {
|
||||||
LogModule.report(logvisor::Info, FMT_STRING("Loaded {} in area {}"), ent->GetName(), ent->GetAreaIdAlways());
|
LogModule.report(logvisor::Info, FMT_STRING("Loaded {} in area {}"), ent->GetName(), ent->GetAreaIdAlways());
|
||||||
|
|
|
@ -12,17 +12,17 @@ public:
|
||||||
double report(const char* name) const {
|
double report(const char* name) const {
|
||||||
double t = std::chrono::duration_cast<std::chrono::microseconds>(
|
double t = std::chrono::duration_cast<std::chrono::microseconds>(
|
||||||
std::chrono::steady_clock::now() - m_start).count() / 1000000.0;
|
std::chrono::steady_clock::now() - m_start).count() / 1000000.0;
|
||||||
#ifndef NDEBUG
|
//#ifndef NDEBUG
|
||||||
fmt::print(FMT_STRING("{} {}\n"), name, t);
|
// fmt::print(FMT_STRING("{} {}\n"), name, t);
|
||||||
#endif
|
//#endif
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
double reportReset(const char* name) {
|
double reportReset(const char* name) {
|
||||||
std::chrono::steady_clock::time_point now = std::chrono::steady_clock::now();
|
std::chrono::steady_clock::time_point now = std::chrono::steady_clock::now();
|
||||||
double t = std::chrono::duration_cast<std::chrono::microseconds>(now - m_start).count() / 1000000.0;
|
double t = std::chrono::duration_cast<std::chrono::microseconds>(now - m_start).count() / 1000000.0;
|
||||||
#ifndef NDEBUG
|
//#ifndef NDEBUG
|
||||||
fmt::print(FMT_STRING("{} {}\n"), name, t);
|
// fmt::print(FMT_STRING("{} {}\n"), name, t);
|
||||||
#endif
|
//#endif
|
||||||
m_start = now;
|
m_start = now;
|
||||||
return t;
|
return t;
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,7 +107,7 @@ public:
|
||||||
TToken(std::unique_ptr<T>&& obj) : CToken(GetIObjObjectFor(std::move(obj))) {}
|
TToken(std::unique_ptr<T>&& obj) : CToken(GetIObjObjectFor(std::move(obj))) {}
|
||||||
TToken& operator=(std::unique_ptr<T>&& obj) {
|
TToken& operator=(std::unique_ptr<T>&& obj) {
|
||||||
*this = CToken(GetIObjObjectFor(std::move(obj)));
|
*this = CToken(GetIObjObjectFor(std::move(obj)));
|
||||||
return this;
|
return *this;
|
||||||
}
|
}
|
||||||
virtual void Unlock() { CToken::Unlock(); }
|
virtual void Unlock() { CToken::Unlock(); }
|
||||||
virtual void Lock() { CToken::Lock(); }
|
virtual void Lock() { CToken::Lock(); }
|
||||||
|
|
|
@ -5,14 +5,13 @@
|
||||||
|
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
|
#include "Runtime/Graphics/CTexture.hpp"
|
||||||
#include "Runtime/Graphics/Shaders/CCameraBlurFilter.hpp"
|
#include "Runtime/Graphics/Shaders/CCameraBlurFilter.hpp"
|
||||||
#include "Runtime/Graphics/Shaders/CXRayBlurFilter.hpp"
|
#include "Runtime/Graphics/Shaders/CXRayBlurFilter.hpp"
|
||||||
|
|
||||||
#include <zeus/CColor.hpp>
|
#include <zeus/CColor.hpp>
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CTexture;
|
|
||||||
|
|
||||||
enum class EFilterType {
|
enum class EFilterType {
|
||||||
Passthru,
|
Passthru,
|
||||||
Multiply,
|
Multiply,
|
||||||
|
|
|
@ -5,10 +5,10 @@
|
||||||
#include "Runtime/CRandom16.hpp"
|
#include "Runtime/CRandom16.hpp"
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "Runtime/GCNTypes.hpp"
|
#include "Runtime/GCNTypes.hpp"
|
||||||
|
#include "Runtime/Character/CTransitionDatabaseGame.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CSimplePool;
|
class CSimplePool;
|
||||||
class CTransitionDatabaseGame;
|
|
||||||
|
|
||||||
struct CAnimSysContext {
|
struct CAnimSysContext {
|
||||||
TToken<CTransitionDatabaseGame> x0_transDB;
|
TToken<CTransitionDatabaseGame> x0_transDB;
|
||||||
|
|
|
@ -3,13 +3,12 @@
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
|
#include "Runtime/Character/CAnimationDatabaseGame.hpp"
|
||||||
#include "Runtime/Character/CAnimSysContext.hpp"
|
#include "Runtime/Character/CAnimSysContext.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CAnimTreeNode;
|
class CAnimTreeNode;
|
||||||
class CAnimationDatabaseGame;
|
|
||||||
class CSimplePool;
|
class CSimplePool;
|
||||||
class CTransitionDatabaseGame;
|
|
||||||
class IMetaAnim;
|
class IMetaAnim;
|
||||||
|
|
||||||
struct CMetaAnimTreeBuildOrders;
|
struct CMetaAnimTreeBuildOrders;
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
|
#include "Runtime/Character/CCharLayoutInfo.hpp"
|
||||||
#include "Runtime/Character/CSegId.hpp"
|
#include "Runtime/Character/CSegId.hpp"
|
||||||
|
|
||||||
#include <zeus/CMatrix3f.hpp>
|
#include <zeus/CMatrix3f.hpp>
|
||||||
|
@ -12,8 +13,6 @@
|
||||||
#include <zeus/CVector3f.hpp>
|
#include <zeus/CVector3f.hpp>
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CCharLayoutInfo;
|
|
||||||
|
|
||||||
class CPoseAsTransforms {
|
class CPoseAsTransforms {
|
||||||
friend class CAnimData;
|
friend class CAnimData;
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -9,9 +9,9 @@
|
||||||
#include "Runtime/Character/CInt32POINode.hpp"
|
#include "Runtime/Character/CInt32POINode.hpp"
|
||||||
#include "Runtime/Character/CParticlePOINode.hpp"
|
#include "Runtime/Character/CParticlePOINode.hpp"
|
||||||
#include "Runtime/Character/CSoundPOINode.hpp"
|
#include "Runtime/Character/CSoundPOINode.hpp"
|
||||||
|
#include "Runtime/Character/CTransitionDatabaseGame.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CTransitionDatabaseGame;
|
|
||||||
class IMetaAnim;
|
class IMetaAnim;
|
||||||
|
|
||||||
class CSequenceFundamentals {
|
class CSequenceFundamentals {
|
||||||
|
|
|
@ -4,12 +4,12 @@
|
||||||
|
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "Runtime/Character/CAnimSysContext.hpp"
|
#include "Runtime/Character/CAnimSysContext.hpp"
|
||||||
|
#include "Runtime/Character/CTransitionDatabaseGame.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CAnimTreeNode;
|
class CAnimTreeNode;
|
||||||
class CRandom16;
|
class CRandom16;
|
||||||
class CSimplePool;
|
class CSimplePool;
|
||||||
class CTransitionDatabaseGame;
|
|
||||||
|
|
||||||
class CTransitionManager {
|
class CTransitionManager {
|
||||||
CAnimSysContext x0_animCtx;
|
CAnimSysContext x0_animCtx;
|
||||||
|
|
|
@ -14,15 +14,15 @@ namespace urde {
|
||||||
|
|
||||||
CActorList::CActorList() : CObjectList(EGameObjectList::Actor) {}
|
CActorList::CActorList() : CObjectList(EGameObjectList::Actor) {}
|
||||||
|
|
||||||
bool CActorList::IsQualified(const CEntity& ent) const { return TCastToConstPtr<CActor>(ent); }
|
bool CActorList::IsQualified(const CEntity& ent) const { return TCastToConstPtr<CActor>(ent).IsValid(); }
|
||||||
|
|
||||||
CPhysicsActorList::CPhysicsActorList() : CObjectList(EGameObjectList::PhysicsActor) {}
|
CPhysicsActorList::CPhysicsActorList() : CObjectList(EGameObjectList::PhysicsActor) {}
|
||||||
|
|
||||||
bool CPhysicsActorList::IsQualified(const CEntity& ent) const { return TCastToConstPtr<CPhysicsActor>(ent); }
|
bool CPhysicsActorList::IsQualified(const CEntity& ent) const { return TCastToConstPtr<CPhysicsActor>(ent).IsValid(); }
|
||||||
|
|
||||||
CGameCameraList::CGameCameraList() : CObjectList(EGameObjectList::GameCamera) {}
|
CGameCameraList::CGameCameraList() : CObjectList(EGameObjectList::GameCamera) {}
|
||||||
|
|
||||||
bool CGameCameraList::IsQualified(const CEntity& ent) const { return TCastToConstPtr<CGameCamera>(ent); }
|
bool CGameCameraList::IsQualified(const CEntity& ent) const { return TCastToConstPtr<CGameCamera>(ent).IsValid(); }
|
||||||
|
|
||||||
CListeningAiList::CListeningAiList() : CObjectList(EGameObjectList::ListeningAi) {}
|
CListeningAiList::CListeningAiList() : CObjectList(EGameObjectList::ListeningAi) {}
|
||||||
|
|
||||||
|
@ -41,12 +41,14 @@ CPlatformAndDoorList::CPlatformAndDoorList() : CObjectList(EGameObjectList::Plat
|
||||||
|
|
||||||
bool CPlatformAndDoorList::IsQualified(const CEntity& ent) const { return IsDoor(ent) || IsPlatform(ent); }
|
bool CPlatformAndDoorList::IsQualified(const CEntity& ent) const { return IsDoor(ent) || IsPlatform(ent); }
|
||||||
|
|
||||||
bool CPlatformAndDoorList::IsDoor(const CEntity& ent) const { return TCastToConstPtr<CScriptDoor>(ent); }
|
bool CPlatformAndDoorList::IsDoor(const CEntity& ent) const { return TCastToConstPtr<CScriptDoor>(ent).IsValid(); }
|
||||||
|
|
||||||
bool CPlatformAndDoorList::IsPlatform(const CEntity& ent) const { return TCastToConstPtr<CScriptPlatform>(ent); }
|
bool CPlatformAndDoorList::IsPlatform(const CEntity& ent) const {
|
||||||
|
return TCastToConstPtr<CScriptPlatform>(ent).IsValid();
|
||||||
|
}
|
||||||
|
|
||||||
CGameLightList::CGameLightList() : CObjectList(EGameObjectList::GameLight) {}
|
CGameLightList::CGameLightList() : CObjectList(EGameObjectList::GameLight) {}
|
||||||
|
|
||||||
bool CGameLightList::IsQualified(const CEntity& lt) const { return TCastToConstPtr<CGameLight>(lt); }
|
bool CGameLightList::IsQualified(const CEntity& lt) const { return TCastToConstPtr<CGameLight>(lt).IsValid(); }
|
||||||
|
|
||||||
} // namespace urde
|
} // namespace urde
|
||||||
|
|
|
@ -5,12 +5,13 @@
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "DNACommon/CMDL.hpp"
|
#include "DataSpec/DNACommon/CMDL.hpp"
|
||||||
#include "DNAMP1/CMDLMaterials.hpp"
|
#include "DataSpec/DNAMP1/CMDLMaterials.hpp"
|
||||||
#include "Runtime/CFactoryMgr.hpp"
|
#include "Runtime/CFactoryMgr.hpp"
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
#include "Shaders/CModelShaders.hpp"
|
#include "Runtime/Graphics/CTexture.hpp"
|
||||||
|
#include "Runtime/Graphics/Shaders/CModelShaders.hpp"
|
||||||
|
|
||||||
#include <boo/graphicsdev/IGraphicsDataFactory.hpp>
|
#include <boo/graphicsdev/IGraphicsDataFactory.hpp>
|
||||||
#include <hecl/HMDLMeta.hpp>
|
#include <hecl/HMDLMeta.hpp>
|
||||||
|
@ -22,7 +23,6 @@ class CLight;
|
||||||
class CModel;
|
class CModel;
|
||||||
class CPoseAsTransforms;
|
class CPoseAsTransforms;
|
||||||
class CSkinRules;
|
class CSkinRules;
|
||||||
class CTexture;
|
|
||||||
class IObjectStore;
|
class IObjectStore;
|
||||||
|
|
||||||
struct CModelFlags {
|
struct CModelFlags {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#include "Runtime/Graphics/Shaders/CTextSupportShader.hpp"
|
#include "Runtime/Graphics/Shaders/CTextSupportShader.hpp"
|
||||||
|
|
||||||
|
#include "Runtime/GuiSys/CFontImageDef.hpp"
|
||||||
#include "Runtime/GuiSys/CRasterFont.hpp"
|
#include "Runtime/GuiSys/CRasterFont.hpp"
|
||||||
|
|
||||||
#include <hecl/Pipeline.hpp>
|
#include <hecl/Pipeline.hpp>
|
||||||
|
|
|
@ -69,9 +69,9 @@ void CAuiImagePane::DoDrawImagePane(const zeus::CColor& color, const CTexture& t
|
||||||
const zeus::CVector2f res(xb8_tex0Tok->GetWidth(), xb8_tex0Tok->GetHeight());
|
const zeus::CVector2f res(xb8_tex0Tok->GetWidth(), xb8_tex0Tok->GetHeight());
|
||||||
const zeus::CVector2f tmp = res / x138_tileSize;
|
const zeus::CVector2f tmp = res / x138_tileSize;
|
||||||
const zeus::CVector2f tmpRecip = x138_tileSize / res;
|
const zeus::CVector2f tmpRecip = x138_tileSize / res;
|
||||||
const float x0 = tmpRecip.x() * (frame % int(tmp.x()));
|
const float x0 = tmpRecip.x() * static_cast<float>(frame % static_cast<int>(tmp.x()));
|
||||||
const float x1 = x0 + tmpRecip.x();
|
const float x1 = x0 + tmpRecip.x();
|
||||||
const float y0 = tmpRecip.y() * (frame % int(tmp.y()));
|
const float y0 = tmpRecip.y() * static_cast<float>(frame % static_cast<int>(tmp.y()));
|
||||||
const float y1 = y0 + tmpRecip.y();
|
const float y1 = y0 + tmpRecip.y();
|
||||||
vec.push_back(zeus::CVector2f(x0, y0));
|
vec.push_back(zeus::CVector2f(x0, y0));
|
||||||
vec.push_back(zeus::CVector2f(x0, y1));
|
vec.push_back(zeus::CVector2f(x0, y1));
|
||||||
|
@ -96,7 +96,7 @@ void CAuiImagePane::DoDrawImagePane(const zeus::CColor& color, const CTexture& t
|
||||||
} else {
|
} else {
|
||||||
const float tmp = (1.f - x14c_deResFactor) * alpha;
|
const float tmp = (1.f - x14c_deResFactor) * alpha;
|
||||||
const float tmp3 = 1.f - tmp * tmp * tmp;
|
const float tmp3 = 1.f - tmp * tmp * tmp;
|
||||||
const float mip = tmp3 * (tex.GetNumMips() - 1);
|
const float mip = tmp3 * static_cast<float>(tex.GetNumMips() - 1);
|
||||||
quad.drawVerts(useColor, verts, mip);
|
quad.drawVerts(useColor, verts, mip);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -117,11 +117,11 @@ void CAuiImagePane::Draw(const CGuiWidgetDrawParms& params) {
|
||||||
// SetZUpdate(xac_drawFlags == EGuiModelDrawFlags::Shadeless || xac_drawFlags == EGuiModelDrawFlags::Opaque);
|
// SetZUpdate(xac_drawFlags == EGuiModelDrawFlags::Shadeless || xac_drawFlags == EGuiModelDrawFlags::Opaque);
|
||||||
float blur0 = 1.f;
|
float blur0 = 1.f;
|
||||||
float blur1 = 0.f;
|
float blur1 = 0.f;
|
||||||
int frame0 = x144_frameTimer;
|
const int frame0 = static_cast<int>(x144_frameTimer);
|
||||||
int frame1 = 0;
|
int frame1 = 0;
|
||||||
if (x140_interval < 1.f && x140_interval > 0.f) {
|
if (x140_interval < 1.f && x140_interval > 0.f) {
|
||||||
zeus::CVector2f tmp = zeus::CVector2f(xb8_tex0Tok->GetWidth(), xb8_tex0Tok->GetHeight()) / x138_tileSize;
|
zeus::CVector2f tmp = zeus::CVector2f(xb8_tex0Tok->GetWidth(), xb8_tex0Tok->GetHeight()) / x138_tileSize;
|
||||||
frame1 = (frame0 + 1) % int(tmp.x() * tmp.y());
|
frame1 = (frame0 + 1) % static_cast<int>(tmp.x() * tmp.y());
|
||||||
if (x148_fadeDuration == 0.f)
|
if (x148_fadeDuration == 0.f)
|
||||||
blur1 = 1.f;
|
blur1 = 1.f;
|
||||||
else
|
else
|
||||||
|
|
|
@ -220,7 +220,7 @@ void CCompoundTargetReticle::Update(float dt, const CStateManager& mgr) {
|
||||||
std::max(x214_fullChargeFadeTimer - dt / g_tweakTargeting->GetFullChargeFadeDuration(), 0.f);
|
std::max(x214_fullChargeFadeTimer - dt / g_tweakTargeting->GetFullChargeFadeDuration(), 0.f);
|
||||||
}
|
}
|
||||||
|
|
||||||
const bool missileActive = gun->GetMissleMode() == CPlayerGun::EMissleMode::Active;
|
const bool missileActive = gun->GetMissleMode() == CPlayerGun::EMissileMode::Active;
|
||||||
if (missileActive != x1f4_missileActive) {
|
if (missileActive != x1f4_missileActive) {
|
||||||
if (x1f8_missileBracketTimer != 0.f) {
|
if (x1f8_missileBracketTimer != 0.f) {
|
||||||
x1f8_missileBracketTimer = FLT_EPSILON - x1f8_missileBracketTimer;
|
x1f8_missileBracketTimer = FLT_EPSILON - x1f8_missileBracketTimer;
|
||||||
|
|
|
@ -9,12 +9,12 @@
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
#include "Runtime/GuiSys/CGuiWidget.hpp"
|
#include "Runtime/GuiSys/CGuiWidget.hpp"
|
||||||
|
#include "Runtime/GuiSys/CRasterFont.hpp"
|
||||||
#include "Runtime/GuiSys/CTextRenderBuffer.hpp"
|
#include "Runtime/GuiSys/CTextRenderBuffer.hpp"
|
||||||
|
|
||||||
#include <zeus/CColor.hpp>
|
#include <zeus/CColor.hpp>
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CRasterFont;
|
|
||||||
class CSimplePool;
|
class CSimplePool;
|
||||||
class CTextExecuteBuffer;
|
class CTextExecuteBuffer;
|
||||||
class CTextRenderBuffer;
|
class CTextRenderBuffer;
|
||||||
|
@ -34,8 +34,6 @@ enum class EVerticalJustification {
|
||||||
RightMono
|
RightMono
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class EColorType { Main, Outline, Geometry, Foreground, Background };
|
|
||||||
|
|
||||||
enum class ETextDirection { Horizontal, Vertical };
|
enum class ETextDirection { Horizontal, Vertical };
|
||||||
|
|
||||||
class CGuiTextProperties {
|
class CGuiTextProperties {
|
||||||
|
|
|
@ -8,7 +8,6 @@
|
||||||
#include "Runtime/GCNTypes.hpp"
|
#include "Runtime/GCNTypes.hpp"
|
||||||
#include "Runtime/IOStreams.hpp"
|
#include "Runtime/IOStreams.hpp"
|
||||||
#include "Runtime/Graphics/CTexture.hpp"
|
#include "Runtime/Graphics/CTexture.hpp"
|
||||||
#include "Runtime/GuiSys/CGuiTextSupport.hpp"
|
|
||||||
|
|
||||||
#include <zeus/CVector2i.hpp>
|
#include <zeus/CVector2i.hpp>
|
||||||
|
|
||||||
|
@ -17,6 +16,8 @@ class CDrawStringOptions;
|
||||||
class CTextRenderBuffer;
|
class CTextRenderBuffer;
|
||||||
class IObjectStore;
|
class IObjectStore;
|
||||||
|
|
||||||
|
enum class EColorType { Main, Outline, Geometry, Foreground, Background };
|
||||||
|
|
||||||
/* NOTE: Is this a good place for CGlyph and CKernPair? */
|
/* NOTE: Is this a good place for CGlyph and CKernPair? */
|
||||||
class CGlyph {
|
class CGlyph {
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -6,12 +6,11 @@
|
||||||
#include "Runtime/GCNTypes.hpp"
|
#include "Runtime/GCNTypes.hpp"
|
||||||
#include "Runtime/GuiSys/CDrawStringOptions.hpp"
|
#include "Runtime/GuiSys/CDrawStringOptions.hpp"
|
||||||
#include "Runtime/GuiSys/CGuiTextSupport.hpp"
|
#include "Runtime/GuiSys/CGuiTextSupport.hpp"
|
||||||
|
#include "Runtime/GuiSys/CRasterFont.hpp"
|
||||||
|
|
||||||
#include <zeus/CColor.hpp>
|
#include <zeus/CColor.hpp>
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CRasterFont;
|
|
||||||
|
|
||||||
class CSaveableState {
|
class CSaveableState {
|
||||||
friend class CColorOverrideInstruction;
|
friend class CColorOverrideInstruction;
|
||||||
friend class CFontInstruction;
|
friend class CFontInstruction;
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
|
|
||||||
#include "DataSpec/DNACommon/Tweaks/ITweakGui.hpp"
|
#include "DataSpec/DNACommon/Tweaks/ITweakGui.hpp"
|
||||||
|
|
||||||
|
#include "Runtime/CDependencyGroup.hpp"
|
||||||
#include "Runtime/CRandom16.hpp"
|
#include "Runtime/CRandom16.hpp"
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "Runtime/CStateManager.hpp"
|
#include "Runtime/CStateManager.hpp"
|
||||||
|
@ -30,7 +31,6 @@ namespace urde {
|
||||||
class CActorLights;
|
class CActorLights;
|
||||||
class CArchitectureQueue;
|
class CArchitectureQueue;
|
||||||
class CAutoMapper;
|
class CAutoMapper;
|
||||||
class CDependencyGroup;
|
|
||||||
class CGuiCamera;
|
class CGuiCamera;
|
||||||
class CGuiModel;
|
class CGuiModel;
|
||||||
class CModelData;
|
class CModelData;
|
||||||
|
|
|
@ -139,7 +139,7 @@ void CSamusHud::InitializeFrameGlueMutable(const CStateManager& mgr) {
|
||||||
CPlayerState& playerState = *mgr.GetPlayerState();
|
CPlayerState& playerState = *mgr.GetPlayerState();
|
||||||
CPlayerGun& gun = *player.GetPlayerGun();
|
CPlayerGun& gun = *player.GetPlayerGun();
|
||||||
float chargeFactor = gun.IsCharging() ? gun.GetChargeBeamFactor() : 0.f;
|
float chargeFactor = gun.IsCharging() ? gun.GetChargeBeamFactor() : 0.f;
|
||||||
bool missilesActive = gun.GetMissleMode() == CPlayerGun::EMissleMode::Active;
|
bool missilesActive = gun.GetMissleMode() == CPlayerGun::EMissileMode::Active;
|
||||||
bool lockedOnObj = player.GetOrbitTargetId() != kInvalidUniqueId;
|
bool lockedOnObj = player.GetOrbitTargetId() != kInvalidUniqueId;
|
||||||
|
|
||||||
switch (x2bc_nextState) {
|
switch (x2bc_nextState) {
|
||||||
|
@ -477,7 +477,7 @@ void CSamusHud::UpdateMissile(float dt, const CStateManager& mgr, bool init) {
|
||||||
|
|
||||||
u32 numMissles = playerState.GetItemAmount(CPlayerState::EItemType::Missiles);
|
u32 numMissles = playerState.GetItemAmount(CPlayerState::EItemType::Missiles);
|
||||||
u32 missileCap = playerState.GetItemCapacity(CPlayerState::EItemType::Missiles);
|
u32 missileCap = playerState.GetItemCapacity(CPlayerState::EItemType::Missiles);
|
||||||
CPlayerGun::EMissleMode missileMode = gun.GetMissleMode();
|
CPlayerGun::EMissileMode missileMode = gun.GetMissleMode();
|
||||||
float chargeFactor = gun.IsCharging() ? gun.GetChargeBeamFactor() : 0.f;
|
float chargeFactor = gun.IsCharging() ? gun.GetChargeBeamFactor() : 0.f;
|
||||||
|
|
||||||
if (x294_missileIntf)
|
if (x294_missileIntf)
|
||||||
|
@ -491,7 +491,7 @@ void CSamusHud::UpdateMissile(float dt, const CStateManager& mgr, bool init) {
|
||||||
if (numMissles != x2d8_missileAmount)
|
if (numMissles != x2d8_missileAmount)
|
||||||
x294_missileIntf->SetNumMissiles(numMissles, mgr);
|
x294_missileIntf->SetNumMissiles(numMissles, mgr);
|
||||||
if (missileMode != x2ec_missileMode)
|
if (missileMode != x2ec_missileMode)
|
||||||
x294_missileIntf->SetIsMissilesActive(missileMode == CPlayerGun::EMissleMode::Active);
|
x294_missileIntf->SetIsMissilesActive(missileMode == CPlayerGun::EMissileMode::Active);
|
||||||
}
|
}
|
||||||
x2d8_missileAmount = numMissles;
|
x2d8_missileAmount = numMissles;
|
||||||
x2ec_missileMode = missileMode;
|
x2ec_missileMode = missileMode;
|
||||||
|
@ -600,7 +600,7 @@ void CSamusHud::UpdateCameraDebugSettings() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSamusHud::UpdateEnergyLow(float dt, const CStateManager& mgr) {
|
void CSamusHud::UpdateEnergyLow(float dt, const CStateManager& mgr) {
|
||||||
bool cineCam = TCastToConstPtr<CCinematicCamera>(mgr.GetCameraManager()->GetCurrentCamera(mgr));
|
const bool cineCam = TCastToConstPtr<CCinematicCamera>(mgr.GetCameraManager()->GetCurrentCamera(mgr)).IsValid();
|
||||||
float oldTimer = x57c_energyLowTimer;
|
float oldTimer = x57c_energyLowTimer;
|
||||||
|
|
||||||
x57c_energyLowTimer = std::fmod(x57c_energyLowTimer + dt, 0.5f);
|
x57c_energyLowTimer = std::fmod(x57c_energyLowTimer + dt, 0.5f);
|
||||||
|
|
|
@ -101,7 +101,7 @@ class CSamusHud {
|
||||||
bool x2e0_27_energyLow : 1;
|
bool x2e0_27_energyLow : 1;
|
||||||
u32 x2e4_ = 0;
|
u32 x2e4_ = 0;
|
||||||
u32 x2e8_ = 0;
|
u32 x2e8_ = 0;
|
||||||
CPlayerGun::EMissleMode x2ec_missileMode = CPlayerGun::EMissleMode::Inactive;
|
CPlayerGun::EMissileMode x2ec_missileMode = CPlayerGun::EMissileMode::Inactive;
|
||||||
float x2f0_visorBeamMenuAlpha = 1.f;
|
float x2f0_visorBeamMenuAlpha = 1.f;
|
||||||
zeus::CVector3f x2f8_fpCamDir;
|
zeus::CVector3f x2f8_fpCamDir;
|
||||||
zeus::CVector3f x304_basewidgetIdlePos;
|
zeus::CVector3f x304_basewidgetIdlePos;
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
#include "Runtime/CDependencyGroup.hpp"
|
||||||
#include "Runtime/CIOWin.hpp"
|
#include "Runtime/CIOWin.hpp"
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
|
@ -16,7 +17,6 @@
|
||||||
#include <zeus/CVector2f.hpp>
|
#include <zeus/CVector2f.hpp>
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CDependencyGroup;
|
|
||||||
class CTexture;
|
class CTexture;
|
||||||
|
|
||||||
class CSlideShow : public CIOWin {
|
class CSlideShow : public CIOWin {
|
||||||
|
|
|
@ -297,9 +297,9 @@ void CFlaahgra::DoUserAnimEvent(CStateManager& mgr, const CInt32POINode& node, E
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
case EUserEventType::BeginAction: {
|
case EUserEventType::BeginAction: {
|
||||||
#ifndef NDEBUG
|
//#ifndef NDEBUG
|
||||||
printf("BeginAction\n");
|
// printf("BeginAction\n");
|
||||||
#endif
|
//#endif
|
||||||
x8e4_26_ = true;
|
x8e4_26_ = true;
|
||||||
x7c4_ = GetEndActionTime();
|
x7c4_ = GetEndActionTime();
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -132,7 +132,8 @@ headerf.write('''
|
||||||
operator T*() const { return GetPtr(); }
|
operator T*() const { return GetPtr(); }
|
||||||
T& operator*() const { return *GetPtr(); }
|
T& operator*() const { return *GetPtr(); }
|
||||||
T* operator->() const { return GetPtr(); }
|
T* operator->() const { return GetPtr(); }
|
||||||
operator bool() const { return ptr != nullptr; }
|
bool IsValid() const { return ptr != nullptr; }
|
||||||
|
explicit operator bool() const { return IsValid(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
|
@ -147,7 +148,8 @@ public:
|
||||||
operator const T*() const { return GetPtr(); }
|
operator const T*() const { return GetPtr(); }
|
||||||
const T& operator*() const { return *GetPtr(); }
|
const T& operator*() const { return *GetPtr(); }
|
||||||
const T* operator->() const { return GetPtr(); }
|
const T* operator->() const { return GetPtr(); }
|
||||||
operator bool() const { return TCastToPtr<T>::ptr != nullptr; }
|
bool IsValid() const { return TCastToPtr<T>::ptr != nullptr; }
|
||||||
|
explicit operator bool() const { return IsValid(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include "Runtime/IOStreams.hpp"
|
#include "Runtime/IOStreams.hpp"
|
||||||
#include "Runtime/IObj.hpp"
|
#include "Runtime/IObj.hpp"
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
|
#include "Runtime/Graphics/CModel.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CColorElement;
|
class CColorElement;
|
||||||
|
@ -16,7 +17,6 @@ class CEmitterElement;
|
||||||
class CGenDescription;
|
class CGenDescription;
|
||||||
class CIntElement;
|
class CIntElement;
|
||||||
class CModVectorElement;
|
class CModVectorElement;
|
||||||
class CModel;
|
|
||||||
class CRealElement;
|
class CRealElement;
|
||||||
class CSimplePool;
|
class CSimplePool;
|
||||||
class CSwooshDescription;
|
class CSwooshDescription;
|
||||||
|
@ -100,3 +100,9 @@ CFactoryFnReturn FParticleFactory(const SObjectTag& tag, CInputStream& in, const
|
||||||
CObjectReference* selfRef);
|
CObjectReference* selfRef);
|
||||||
|
|
||||||
} // namespace urde
|
} // namespace urde
|
||||||
|
|
||||||
|
// FIXME hacky workaround for MSVC; these need to be complete types
|
||||||
|
// but introduce circular dependencies if included at the start
|
||||||
|
#include "Runtime/Particle/CGenDescription.hpp"
|
||||||
|
#include "Runtime/Particle/CSwooshDescription.hpp"
|
||||||
|
#include "Runtime/Particle/CElectricDescription.hpp"
|
|
@ -19,9 +19,15 @@ CBurstFire::CBurstFire(const SBurst* const* burstDefs, s32 firstBurstCount)
|
||||||
|
|
||||||
void CBurstFire::Update(CStateManager& mgr, float dt) {
|
void CBurstFire::Update(CStateManager& mgr, float dt) {
|
||||||
x14_24_shouldFire = false;
|
x14_24_shouldFire = false;
|
||||||
if (x18_curBursts) {
|
if (!x18_curBursts) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
x8_timeToNextShot -= dt;
|
x8_timeToNextShot -= dt;
|
||||||
if (x8_timeToNextShot < 0.f) {
|
if (x8_timeToNextShot >= 0.f) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
x4_angleIdx += 1;
|
x4_angleIdx += 1;
|
||||||
if (x18_curBursts->x4_shotAngles[x4_angleIdx] > 0) {
|
if (x18_curBursts->x4_shotAngles[x4_angleIdx] > 0) {
|
||||||
x14_24_shouldFire = true;
|
x14_24_shouldFire = true;
|
||||||
|
@ -31,8 +37,6 @@ void CBurstFire::Update(CStateManager& mgr, float dt) {
|
||||||
x18_curBursts = nullptr;
|
x18_curBursts = nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
zeus::CVector3f CBurstFire::GetDistanceCompensatedError(float dist, float maxErrDist) const {
|
zeus::CVector3f CBurstFire::GetDistanceCompensatedError(float dist, float maxErrDist) const {
|
||||||
float xErr = GetMaxXError();
|
float xErr = GetMaxXError();
|
||||||
|
@ -67,18 +71,25 @@ void CBurstFire::Start(CStateManager& mgr) {
|
||||||
}
|
}
|
||||||
|
|
||||||
zeus::CVector3f CBurstFire::GetError(float xMag, float zMag) const {
|
zeus::CVector3f CBurstFire::GetError(float xMag, float zMag) const {
|
||||||
zeus::CVector3f ret;
|
if (!x14_24_shouldFire || !x18_curBursts) {
|
||||||
if (x14_24_shouldFire && x18_curBursts) {
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
s32 r0 = x18_curBursts->x4_shotAngles[x4_angleIdx];
|
s32 r0 = x18_curBursts->x4_shotAngles[x4_angleIdx];
|
||||||
if (x14_25_avoidAccuracy && (r0 == 4 || r0 == 12))
|
if (x14_25_avoidAccuracy && (r0 == 4 || r0 == 12)) {
|
||||||
r0 = x4_angleIdx > 0 ? x18_curBursts->x4_shotAngles[x4_angleIdx - 1]
|
r0 =
|
||||||
: x18_curBursts->x4_shotAngles[x4_angleIdx + 1];
|
x4_angleIdx > 0 ? x18_curBursts->x4_shotAngles[x4_angleIdx - 1] : x18_curBursts->x4_shotAngles[x4_angleIdx + 1];
|
||||||
if (r0 > 0) {
|
}
|
||||||
float angle = r0 * zeus::degToRad(-22.5f);
|
|
||||||
|
if (r0 <= 0) {
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
const float angle = r0 * zeus::degToRad(-22.5f);
|
||||||
|
zeus::CVector3f ret;
|
||||||
ret.x() = std::cos(angle) * xMag;
|
ret.x() = std::cos(angle) * xMag;
|
||||||
ret.z() = std::sin(angle) * zMag;
|
ret.z() = std::sin(angle) * zMag;
|
||||||
}
|
|
||||||
}
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
#include "Runtime/Character/CAnimCharacterSet.hpp"
|
#include "Runtime/Character/CAnimCharacterSet.hpp"
|
||||||
#include "Runtime/Collision/CMaterialList.hpp"
|
#include "Runtime/Collision/CMaterialList.hpp"
|
||||||
#include "Runtime/Particle/CElementGen.hpp"
|
#include "Runtime/Particle/CElementGen.hpp"
|
||||||
|
#include "Runtime/Particle/CWeaponDescription.hpp"
|
||||||
#include "Runtime/Weapon/CGunController.hpp"
|
#include "Runtime/Weapon/CGunController.hpp"
|
||||||
#include "Runtime/Weapon/CGunMotion.hpp"
|
#include "Runtime/Weapon/CGunMotion.hpp"
|
||||||
#include "Runtime/Weapon/CWeaponMgr.hpp"
|
#include "Runtime/Weapon/CWeaponMgr.hpp"
|
||||||
|
@ -25,7 +26,6 @@ namespace urde {
|
||||||
|
|
||||||
class CActorLights;
|
class CActorLights;
|
||||||
struct CModelFlags;
|
struct CModelFlags;
|
||||||
class CWeaponDescription;
|
|
||||||
|
|
||||||
enum class EChargeState { Normal, Charged };
|
enum class EChargeState { Normal, Charged };
|
||||||
|
|
||||||
|
|
|
@ -501,7 +501,7 @@ void CPlayerGun::ResetCharge(CStateManager& mgr, bool resetBeam) {
|
||||||
x2f8_stateFlags &= 0xFFE9;
|
x2f8_stateFlags &= 0xFFE9;
|
||||||
}
|
}
|
||||||
x318_comboAmmoIdx = 0;
|
x318_comboAmmoIdx = 0;
|
||||||
x31c_missileMode = EMissleMode::Inactive;
|
x31c_missileMode = EMissileMode::Inactive;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -587,7 +587,7 @@ void CPlayerGun::Reset(CStateManager& mgr, bool b1) {
|
||||||
x2f8_stateFlags &= 0xFFE9;
|
x2f8_stateFlags &= 0xFFE9;
|
||||||
}
|
}
|
||||||
x318_comboAmmoIdx = 0;
|
x318_comboAmmoIdx = 0;
|
||||||
x31c_missileMode = EMissleMode::Inactive;
|
x31c_missileMode = EMissileMode::Inactive;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
x2f8_stateFlags &= ~0x7;
|
x2f8_stateFlags &= ~0x7;
|
||||||
|
@ -784,7 +784,7 @@ void CPlayerGun::CancelFiring(CStateManager& mgr) {
|
||||||
x2f8_stateFlags &= 0xFFE9;
|
x2f8_stateFlags &= 0xFFE9;
|
||||||
}
|
}
|
||||||
x318_comboAmmoIdx = 0;
|
x318_comboAmmoIdx = 0;
|
||||||
x31c_missileMode = EMissleMode::Inactive;
|
x31c_missileMode = EMissileMode::Inactive;
|
||||||
}
|
}
|
||||||
if (x32c_chargePhase != EChargePhase::NotCharging) {
|
if (x32c_chargePhase != EChargePhase::NotCharging) {
|
||||||
x72c_currentBeam->ActivateCharge(false, false);
|
x72c_currentBeam->ActivateCharge(false, false);
|
||||||
|
@ -820,8 +820,7 @@ void CPlayerGun::StopContinuousBeam(CStateManager& mgr, bool b1) {
|
||||||
} else if (x833_28_phazonBeamActive) {
|
} else if (x833_28_phazonBeamActive) {
|
||||||
if (static_cast<CPhazonBeam*>(x72c_currentBeam)->IsFiring())
|
if (static_cast<CPhazonBeam*>(x72c_currentBeam)->IsFiring())
|
||||||
static_cast<CPhazonBeam*>(x72c_currentBeam)->StopBeam(mgr, b1);
|
static_cast<CPhazonBeam*>(x72c_currentBeam)->StopBeam(mgr, b1);
|
||||||
} else if (x310_currentBeam == CPlayerState::EBeamId::Plasma) // Plasma
|
} else if (x310_currentBeam == CPlayerState::EBeamId::Plasma) {
|
||||||
{
|
|
||||||
if (static_cast<CPlasmaBeam*>(x72c_currentBeam)->IsFiring())
|
if (static_cast<CPlasmaBeam*>(x72c_currentBeam)->IsFiring())
|
||||||
static_cast<CPlasmaBeam*>(x72c_currentBeam)->StopBeam(mgr, b1);
|
static_cast<CPlasmaBeam*>(x72c_currentBeam)->StopBeam(mgr, b1);
|
||||||
}
|
}
|
||||||
|
@ -839,9 +838,9 @@ void CPlayerGun::CMotionState::Update(bool firing, float dt, zeus::CTransform& x
|
||||||
|
|
||||||
if (x0_24_extendParabola && x20_state == EMotionState::LockOn) {
|
if (x0_24_extendParabola && x20_state == EMotionState::LockOn) {
|
||||||
float extendT = xc_curExtendDist / gGunExtendDistance;
|
float extendT = xc_curExtendDist / gGunExtendDistance;
|
||||||
xf = xf * zeus::CTransform::RotateZ(zeus::degToRad(extendT * -4.f * (extendT - 1.f) * 15.f));
|
xf = xf * zeus::CTransform(zeus::CMatrix3f::RotateZ(zeus::degToRad(extendT * -4.f * (extendT - 1.f) * 15.f)),
|
||||||
} else {
|
{0.f, xc_curExtendDist, 0.f});
|
||||||
if (x24_fireState == EFireState::StartFire || x24_fireState == EFireState::Firing) {
|
} else if (x24_fireState == EFireState::StartFire || x24_fireState == EFireState::Firing) {
|
||||||
if (std::fabs(x14_rotationT - 1.f) < 0.1f) {
|
if (std::fabs(x14_rotationT - 1.f) < 0.1f) {
|
||||||
x18_startRotation = x1c_endRotation;
|
x18_startRotation = x1c_endRotation;
|
||||||
x14_rotationT = 0.f;
|
x14_rotationT = 0.f;
|
||||||
|
@ -861,14 +860,13 @@ void CPlayerGun::CMotionState::Update(bool firing, float dt, zeus::CTransform& x
|
||||||
|
|
||||||
x14_rotationT += (1.f - x14_rotationT) * 0.8f * (10.f * dt);
|
x14_rotationT += (1.f - x14_rotationT) * 0.8f * (10.f * dt);
|
||||||
zeus::CTransform tmpXf =
|
zeus::CTransform tmpXf =
|
||||||
zeus::CQuaternion::fromAxisAngle(xf.basis[1], zeus::degToRad(x10_curRotation)).toTransform() *
|
zeus::CQuaternion::fromAxisAngle(xf.frontVector(), zeus::degToRad(x10_curRotation)).toTransform() *
|
||||||
xf.getRotation();
|
xf.getRotation();
|
||||||
tmpXf.origin = xf.origin;
|
tmpXf.origin = xf.origin;
|
||||||
xf = tmpXf * zeus::CTransform::Translate(0.f, xc_curExtendDist, 0.f);
|
xf = tmpXf * zeus::CTransform::Translate(0.f, xc_curExtendDist, 0.f);
|
||||||
} else {
|
} else {
|
||||||
xf = xf * zeus::CTransform::Translate(0.f, xc_curExtendDist, 0.f);
|
xf = xf * zeus::CTransform::Translate(0.f, xc_curExtendDist, 0.f);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
switch (x20_state) {
|
switch (x20_state) {
|
||||||
case EMotionState::LockOn:
|
case EMotionState::LockOn:
|
||||||
|
@ -1272,7 +1270,7 @@ void CPlayerGun::UpdateAuxWeapons(float dt, const zeus::CTransform& targetXf, CS
|
||||||
x2f8_stateFlags &= 0xFFE9;
|
x2f8_stateFlags &= 0xFFE9;
|
||||||
}
|
}
|
||||||
x318_comboAmmoIdx = 0;
|
x318_comboAmmoIdx = 0;
|
||||||
x31c_missileMode = EMissleMode::Inactive;
|
x31c_missileMode = EMissileMode::Inactive;
|
||||||
}
|
}
|
||||||
} else if (x833_28_phazonBeamActive) {
|
} else if (x833_28_phazonBeamActive) {
|
||||||
static_cast<CPhazonBeam*>(x72c_currentBeam)->UpdateBeam(dt, targetXf, x418_beamLocalXf.origin, mgr);
|
static_cast<CPhazonBeam*>(x72c_currentBeam)->UpdateBeam(dt, targetXf, x418_beamLocalXf.origin, mgr);
|
||||||
|
@ -1581,7 +1579,7 @@ void CPlayerGun::UpdateWeaponFire(float dt, const CPlayerState& playerState, CSt
|
||||||
x2f8_stateFlags &= ~0x1;
|
x2f8_stateFlags &= ~0x1;
|
||||||
x2f8_stateFlags |= 0x6;
|
x2f8_stateFlags |= 0x6;
|
||||||
x318_comboAmmoIdx = 1;
|
x318_comboAmmoIdx = 1;
|
||||||
x31c_missileMode = EMissleMode::Active;
|
x31c_missileMode = EMissileMode::Active;
|
||||||
}
|
}
|
||||||
FireSecondary(dt, mgr);
|
FireSecondary(dt, mgr);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1875,7 +1873,7 @@ void CPlayerGun::Update(float grappleSwingT, float cameraBobT, float dt, CStateM
|
||||||
x2f8_stateFlags &= ~0x1;
|
x2f8_stateFlags &= ~0x1;
|
||||||
x2f8_stateFlags |= 0x6;
|
x2f8_stateFlags |= 0x6;
|
||||||
x318_comboAmmoIdx = 1;
|
x318_comboAmmoIdx = 1;
|
||||||
x31c_missileMode = EMissleMode::Active;
|
x31c_missileMode = EMissileMode::Active;
|
||||||
break;
|
break;
|
||||||
case ENextState::ExitMissile:
|
case ENextState::ExitMissile:
|
||||||
if ((x2f8_stateFlags & 0x8) != 0x8) {
|
if ((x2f8_stateFlags & 0x8) != 0x8) {
|
||||||
|
@ -1883,7 +1881,7 @@ void CPlayerGun::Update(float grappleSwingT, float cameraBobT, float dt, CStateM
|
||||||
x2f8_stateFlags &= 0xFFE9;
|
x2f8_stateFlags &= 0xFFE9;
|
||||||
}
|
}
|
||||||
x318_comboAmmoIdx = 0;
|
x318_comboAmmoIdx = 0;
|
||||||
x31c_missileMode = EMissleMode::Inactive;
|
x31c_missileMode = EMissileMode::Inactive;
|
||||||
x390_cooldown = x72c_currentBeam->GetWeaponInfo().x0_coolDown;
|
x390_cooldown = x72c_currentBeam->GetWeaponInfo().x0_coolDown;
|
||||||
break;
|
break;
|
||||||
case ENextState::MissileReload:
|
case ENextState::MissileReload:
|
||||||
|
@ -1905,7 +1903,7 @@ void CPlayerGun::Update(float grappleSwingT, float cameraBobT, float dt, CStateM
|
||||||
x2f8_stateFlags &= 0xFFE9;
|
x2f8_stateFlags &= 0xFFE9;
|
||||||
}
|
}
|
||||||
x318_comboAmmoIdx = 0;
|
x318_comboAmmoIdx = 0;
|
||||||
x31c_missileMode = EMissleMode::Inactive;
|
x31c_missileMode = EMissileMode::Inactive;
|
||||||
break;
|
break;
|
||||||
case ENextState::EnterPhazonBeam:
|
case ENextState::EnterPhazonBeam:
|
||||||
if (x75c_phazonBeam->IsLoaded())
|
if (x75c_phazonBeam->IsLoaded())
|
||||||
|
@ -1970,7 +1968,7 @@ void CPlayerGun::Update(float grappleSwingT, float cameraBobT, float dt, CStateM
|
||||||
zeus::CAABox aabb = x72c_currentBeam->GetBounds().getTransformedAABox(x4a8_gunWorldXf);
|
zeus::CAABox aabb = x72c_currentBeam->GetBounds().getTransformedAABox(x4a8_gunWorldXf);
|
||||||
mgr.BuildNearList(nearList, aabb, sAimFilter, &player);
|
mgr.BuildNearList(nearList, aabb, sAimFilter, &player);
|
||||||
TUniqueId bestId = kInvalidUniqueId;
|
TUniqueId bestId = kInvalidUniqueId;
|
||||||
zeus::CVector3f dir = x4a8_gunWorldXf.basis[1].normalized();
|
zeus::CVector3f dir = x4a8_gunWorldXf.frontVector().normalized();
|
||||||
zeus::CVector3f pos = dir * -0.5f + x4a8_gunWorldXf.origin;
|
zeus::CVector3f pos = dir * -0.5f + x4a8_gunWorldXf.origin;
|
||||||
CRayCastResult result = mgr.RayWorldIntersection(bestId, pos, dir, 3.5f, sAimFilter, nearList);
|
CRayCastResult result = mgr.RayWorldIntersection(bestId, pos, dir, 3.5f, sAimFilter, nearList);
|
||||||
x833_29_pointBlankWorldSurface = result.IsValid();
|
x833_29_pointBlankWorldSurface = result.IsValid();
|
||||||
|
|
|
@ -35,7 +35,7 @@ struct CFinalInput;
|
||||||
class CPlayerGun {
|
class CPlayerGun {
|
||||||
public:
|
public:
|
||||||
static float skTractorBeamFactor;
|
static float skTractorBeamFactor;
|
||||||
enum class EMissleMode { Inactive, Active };
|
enum class EMissileMode { Inactive, Active };
|
||||||
enum class EBWeapon { Bomb, PowerBomb };
|
enum class EBWeapon { Bomb, PowerBomb };
|
||||||
enum class EPhazonBeamState { Inactive, Entering, Exiting, Active };
|
enum class EPhazonBeamState { Inactive, Entering, Exiting, Active };
|
||||||
enum class EChargePhase {
|
enum class EChargePhase {
|
||||||
|
@ -141,7 +141,7 @@ private:
|
||||||
CPlayerState::EBeamId x310_currentBeam = CPlayerState::EBeamId::Power;
|
CPlayerState::EBeamId x310_currentBeam = CPlayerState::EBeamId::Power;
|
||||||
CPlayerState::EBeamId x314_nextBeam = CPlayerState::EBeamId::Power;
|
CPlayerState::EBeamId x314_nextBeam = CPlayerState::EBeamId::Power;
|
||||||
u32 x318_comboAmmoIdx = 0;
|
u32 x318_comboAmmoIdx = 0;
|
||||||
EMissleMode x31c_missileMode = EMissleMode::Inactive;
|
EMissileMode x31c_missileMode = EMissileMode::Inactive;
|
||||||
CPlayerState::EBeamId x320_currentAuxBeam = CPlayerState::EBeamId::Power;
|
CPlayerState::EBeamId x320_currentAuxBeam = CPlayerState::EBeamId::Power;
|
||||||
EIdleState x324_idleState = EIdleState::Four;
|
EIdleState x324_idleState = EIdleState::Four;
|
||||||
float x328_animSfxPitch = 0.f;
|
float x328_animSfxPitch = 0.f;
|
||||||
|
@ -323,7 +323,7 @@ public:
|
||||||
void AcceptScriptMsg(EScriptObjectMessage, TUniqueId, CStateManager&);
|
void AcceptScriptMsg(EScriptObjectMessage, TUniqueId, CStateManager&);
|
||||||
void AsyncLoadSuit(CStateManager& mgr);
|
void AsyncLoadSuit(CStateManager& mgr);
|
||||||
void TouchModel(const CStateManager& stateMgr);
|
void TouchModel(const CStateManager& stateMgr);
|
||||||
EMissleMode GetMissleMode() const { return x31c_missileMode; }
|
EMissileMode GetMissleMode() const { return x31c_missileMode; }
|
||||||
bool IsFidgeting() const { return x833_24_notFidgeting; }
|
bool IsFidgeting() const { return x833_24_notFidgeting; }
|
||||||
bool IsCharging() const { return x834_24_charging; }
|
bool IsCharging() const { return x834_24_charging; }
|
||||||
float GetChargeBeamFactor() const { return x340_chargeBeamFactor; }
|
float GetChargeBeamFactor() const { return x340_chargeBeamFactor; }
|
||||||
|
|
|
@ -18,9 +18,10 @@
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
|
|
||||||
static bool IsMediumOrLarge(CActor& act) {
|
static bool IsMediumOrLarge(const CActor& act) {
|
||||||
if (TCastToConstPtr<CPatterned> pat = act)
|
if (const TCastToConstPtr<CPatterned> pat = act) {
|
||||||
return pat->GetKnockBackController().GetVariant() != EKnockBackVariant::Small;
|
return pat->GetKnockBackController().GetVariant() != EKnockBackVariant::Small;
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3323,7 +3323,7 @@ void CPlayer::UpdateAimTargetPrediction(const zeus::CTransform& xf, const CState
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
x9c6_27_aimingAtProjectile = TCastToConstPtr<CGameProjectile>(target.GetPtr());
|
x9c6_27_aimingAtProjectile = TCastToConstPtr<CGameProjectile>(target.GetPtr()).IsValid();
|
||||||
const zeus::CVector3f instantTarget = target->GetAimPosition(mgr, 0.f);
|
const zeus::CVector3f instantTarget = target->GetAimPosition(mgr, 0.f);
|
||||||
const zeus::CVector3f gunToTarget = instantTarget - xf.origin;
|
const zeus::CVector3f gunToTarget = instantTarget - xf.origin;
|
||||||
const float timeToTarget = gunToTarget.magnitude() / x490_gun->GetBeamVelocity();
|
const float timeToTarget = gunToTarget.magnitude() / x490_gun->GetBeamVelocity();
|
||||||
|
@ -5076,7 +5076,7 @@ bool CPlayer::ValidateOrbitTargetIdAndPointer(TUniqueId uid, CStateManager& mgr)
|
||||||
if (uid == kInvalidUniqueId) {
|
if (uid == kInvalidUniqueId) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return TCastToConstPtr<CActor>(mgr.GetObjectById(uid));
|
return TCastToConstPtr<CActor>(mgr.GetObjectById(uid)).IsValid();
|
||||||
}
|
}
|
||||||
|
|
||||||
zeus::CVector3f CPlayer::GetBallPosition() const {
|
zeus::CVector3f CPlayer::GetBallPosition() const {
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include "Runtime/CToken.hpp"
|
#include "Runtime/CToken.hpp"
|
||||||
#include "Runtime/RetroTypes.hpp"
|
#include "Runtime/RetroTypes.hpp"
|
||||||
#include "Runtime/rstl.hpp"
|
#include "Runtime/rstl.hpp"
|
||||||
|
#include "Runtime/Collision/CCollidableOBBTreeGroup.hpp"
|
||||||
#include "Runtime/World/CDamageVulnerability.hpp"
|
#include "Runtime/World/CDamageVulnerability.hpp"
|
||||||
#include "Runtime/World/CHealthInfo.hpp"
|
#include "Runtime/World/CHealthInfo.hpp"
|
||||||
#include "Runtime/World/CPhysicsActor.hpp"
|
#include "Runtime/World/CPhysicsActor.hpp"
|
||||||
|
@ -17,8 +18,6 @@
|
||||||
#include <zeus/CVector3f.hpp>
|
#include <zeus/CVector3f.hpp>
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CCollidableOBBTreeGroup;
|
|
||||||
class CCollidableOBBTreeGroupContainer;
|
|
||||||
class CFluidPlane;
|
class CFluidPlane;
|
||||||
|
|
||||||
struct SRiders {
|
struct SRiders {
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
#include "Runtime/World/CAi.hpp"
|
#include "Runtime/World/CAi.hpp"
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
|
static logvisor::Module Log("urde::CStateMachine");
|
||||||
|
|
||||||
CStateMachine::CStateMachine(CInputStream& in) {
|
CStateMachine::CStateMachine(CInputStream& in) {
|
||||||
CAiTrigger* lastTrig = nullptr;
|
CAiTrigger* lastTrig = nullptr;
|
||||||
u32 stateCount = in.readUint32Big();
|
u32 stateCount = in.readUint32Big();
|
||||||
|
@ -78,10 +80,8 @@ void CStateMachineState::Update(CStateManager& mgr, CAi& ai, float delta) {
|
||||||
if (andPassed && state) {
|
if (andPassed && state) {
|
||||||
x4_state->CallFunc(mgr, ai, EStateMsg::Deactivate, 0.f);
|
x4_state->CallFunc(mgr, ai, EStateMsg::Deactivate, 0.f);
|
||||||
x4_state = state;
|
x4_state = state;
|
||||||
//#ifndef NDEBUG
|
Log.report(logvisor::Info, FMT_STRING("{} {} {} - {} {}"), ai.GetUniqueId(), ai.GetEditorId(), ai.GetName(),
|
||||||
// fmt::print(FMT_STRING("{} {} {} - {} {}\n"), ai.GetUniqueId(), ai.GetEditorId(), ai.GetName(),
|
state->xc_name, int(state - x0_machine->GetStateVector().data()));
|
||||||
// state->xc_name, int(state - x0_machine->GetStateVector().data()));
|
|
||||||
//#endif
|
|
||||||
x8_time = 0.f;
|
x8_time = 0.f;
|
||||||
x18_24_codeTrigger = false;
|
x18_24_codeTrigger = false;
|
||||||
xc_random = mgr.GetActiveRandom()->Float();
|
xc_random = mgr.GetActiveRandom()->Float();
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
#include "Runtime/Graphics/Shaders/CColoredQuadFilter.hpp"
|
#include "Runtime/Graphics/Shaders/CColoredQuadFilter.hpp"
|
||||||
#include "Runtime/Graphics/Shaders/CTexturedQuadFilter.hpp"
|
#include "Runtime/Graphics/Shaders/CTexturedQuadFilter.hpp"
|
||||||
#include "Runtime/GuiSys/CGuiTextSupport.hpp"
|
#include "Runtime/GuiSys/CGuiTextSupport.hpp"
|
||||||
|
#include "Runtime/GuiSys/CStringTable.hpp"
|
||||||
|
|
||||||
#include <zeus/CTransform.hpp>
|
#include <zeus/CTransform.hpp>
|
||||||
#include <zeus/CVector2f.hpp>
|
#include <zeus/CVector2f.hpp>
|
||||||
|
@ -21,7 +22,6 @@
|
||||||
|
|
||||||
namespace urde {
|
namespace urde {
|
||||||
class CSimplePool;
|
class CSimplePool;
|
||||||
class CStringTable;
|
|
||||||
|
|
||||||
class CWorldTransManager {
|
class CWorldTransManager {
|
||||||
public:
|
public:
|
||||||
|
|
2
hecl
2
hecl
|
@ -1 +1 @@
|
||||||
Subproject commit 95ac3ef77c8a5dfe70f498fdffea5fe92091bd73
|
Subproject commit d1ed2b5d4d4ef1a56097492fe8a57c6911adf708
|
2
hecl-gui
2
hecl-gui
|
@ -1 +1 @@
|
||||||
Subproject commit c66d33b0b2fca695c39d1c0c829489ba67a52f47
|
Subproject commit e5e3713b12f6c6b93cae5ca59b1879f45d498f22
|
2
specter
2
specter
|
@ -1 +1 @@
|
||||||
Subproject commit fc0d79ace7063f24efaeaf8153753855eb3e2b95
|
Subproject commit f54b6e2650711b9872b230d27f15e0e231a5f12d
|
Loading…
Reference in New Issue