Add CExplosion

This commit is contained in:
Henrique Gemignani Passos Lima 2022-11-27 02:26:12 +02:00
parent ef3779ac51
commit 147e46d2e8
No known key found for this signature in database
GPG Key ID: E224F951761145F8
22 changed files with 235 additions and 66 deletions

View File

@ -8751,7 +8751,7 @@ lbl_8031F390:
/* 8031F3A0 0031C300 38 04 DD 08 */ addi r0, r4, __vt__12CParticleGen@l /* 8031F3A0 0031C300 38 04 DD 08 */ addi r0, r4, __vt__12CParticleGen@l
/* 8031F3A4 0031C304 38 80 FF FF */ li r4, -1 /* 8031F3A4 0031C304 38 80 FF FF */ li r4, -1
/* 8031F3A8 0031C308 90 1E 00 00 */ stw r0, 0(r30) /* 8031F3A8 0031C308 90 1E 00 00 */ stw r0, 0(r30)
/* 8031F3AC 0031C30C 4B D3 B9 25 */ bl __dt__12CParticleGenFv /* 8031F3AC 0031C30C 4B D3 B9 25 */ bl "__dt__Q24rstl52list<Q24rstl10pair<Us,b>,Q24rstl17rmemory_allocator>Fv"
lbl_8031F3B0: lbl_8031F3B0:
/* 8031F3B0 0031C310 7F E0 07 35 */ extsh. r0, r31 /* 8031F3B0 0031C310 7F E0 07 35 */ extsh. r0, r31
/* 8031F3B4 0031C314 40 81 00 0C */ ble lbl_8031F3C0 /* 8031F3B4 0031C314 40 81 00 0C */ ble lbl_8031F3C0

View File

@ -3909,7 +3909,7 @@ lbl_80361EC0:
/* 80361ED0 0035EE30 38 04 DD 08 */ addi r0, r4, __vt__12CParticleGen@l /* 80361ED0 0035EE30 38 04 DD 08 */ addi r0, r4, __vt__12CParticleGen@l
/* 80361ED4 0035EE34 38 80 FF FF */ li r4, -1 /* 80361ED4 0035EE34 38 80 FF FF */ li r4, -1
/* 80361ED8 0035EE38 90 1E 00 00 */ stw r0, 0(r30) /* 80361ED8 0035EE38 90 1E 00 00 */ stw r0, 0(r30)
/* 80361EDC 0035EE3C 4B CF 8D F5 */ bl __dt__12CParticleGenFv /* 80361EDC 0035EE3C 4B CF 8D F5 */ bl "__dt__Q24rstl52list<Q24rstl10pair<Us,b>,Q24rstl17rmemory_allocator>Fv"
lbl_80361EE0: lbl_80361EE0:
/* 80361EE0 0035EE40 7F E0 07 35 */ extsh. r0, r31 /* 80361EE0 0035EE40 7F E0 07 35 */ extsh. r0, r31
/* 80361EE4 0035EE44 40 81 00 0C */ ble lbl_80361EF0 /* 80361EE4 0035EE44 40 81 00 0C */ ble lbl_80361EF0

View File

@ -4884,7 +4884,7 @@ lbl_8032ED98:
/* 8032EDA8 0032BD08 38 04 DD 08 */ addi r0, r4, __vt__12CParticleGen@l /* 8032EDA8 0032BD08 38 04 DD 08 */ addi r0, r4, __vt__12CParticleGen@l
/* 8032EDAC 0032BD0C 38 80 FF FF */ li r4, -1 /* 8032EDAC 0032BD0C 38 80 FF FF */ li r4, -1
/* 8032EDB0 0032BD10 90 1E 00 00 */ stw r0, 0(r30) /* 8032EDB0 0032BD10 90 1E 00 00 */ stw r0, 0(r30)
/* 8032EDB4 0032BD14 4B D2 BF 1D */ bl __dt__12CParticleGenFv /* 8032EDB4 0032BD14 4B D2 BF 1D */ bl "__dt__Q24rstl52list<Q24rstl10pair<Us,b>,Q24rstl17rmemory_allocator>Fv"
lbl_8032EDB8: lbl_8032EDB8:
/* 8032EDB8 0032BD18 7F E0 07 35 */ extsh. r0, r31 /* 8032EDB8 0032BD18 7F E0 07 35 */ extsh. r0, r31
/* 8032EDBC 0032BD1C 40 81 00 0C */ ble lbl_8032EDC8 /* 8032EDBC 0032BD1C 40 81 00 0C */ ble lbl_8032EDC8

View File

@ -3,8 +3,8 @@
.section .data .section .data
.balign 8 .balign 8
.global lbl_803DA0A8 .global __vt__10CExplosion
lbl_803DA0A8: __vt__10CExplosion:
# ROM: 0x3D70A8 # ROM: 0x3D70A8
.4byte 0 .4byte 0
.4byte 0 .4byte 0
@ -567,9 +567,9 @@ __dt__10CExplosionFv:
/* 8005A850 000577B0 93 C1 00 08 */ stw r30, 8(r1) /* 8005A850 000577B0 93 C1 00 08 */ stw r30, 8(r1)
/* 8005A854 000577B4 7C 7E 1B 79 */ or. r30, r3, r3 /* 8005A854 000577B4 7C 7E 1B 79 */ or. r30, r3, r3
/* 8005A858 000577B8 41 82 00 68 */ beq lbl_8005A8C0 /* 8005A858 000577B8 41 82 00 68 */ beq lbl_8005A8C0
/* 8005A85C 000577BC 3C 60 80 3E */ lis r3, lbl_803DA0A8@ha /* 8005A85C 000577BC 3C 60 80 3E */ lis r3, __vt__10CExplosion@ha
/* 8005A860 000577C0 34 1E 00 E8 */ addic. r0, r30, 0xe8 /* 8005A860 000577C0 34 1E 00 E8 */ addic. r0, r30, 0xe8
/* 8005A864 000577C4 38 03 A0 A8 */ addi r0, r3, lbl_803DA0A8@l /* 8005A864 000577C4 38 03 A0 A8 */ addi r0, r3, __vt__10CExplosion@l
/* 8005A868 000577C8 90 1E 00 00 */ stw r0, 0(r30) /* 8005A868 000577C8 90 1E 00 00 */ stw r0, 0(r30)
/* 8005A86C 000577CC 41 82 00 24 */ beq lbl_8005A890 /* 8005A86C 000577CC 41 82 00 24 */ beq lbl_8005A890
/* 8005A870 000577D0 80 7E 00 E8 */ lwz r3, 0xe8(r30) /* 8005A870 000577D0 80 7E 00 E8 */ lwz r3, 0xe8(r30)
@ -603,8 +603,8 @@ lbl_8005A8C0:
/* 8005A8D4 00057834 38 21 00 10 */ addi r1, r1, 0x10 /* 8005A8D4 00057834 38 21 00 10 */ addi r1, r1, 0x10
/* 8005A8D8 00057838 4E 80 00 20 */ blr /* 8005A8D8 00057838 4E 80 00 20 */ blr
.global "__ct__10CExplosionFRC31TLockedToken<20CElectricDescription>9TUniqueIdbRC11CEntityInfoRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4fUiRC9CVector3fRC6CColor" .global "__ct__10CExplosionFRC36TLockedToken<20CElectricDescription>9TUniqueIdbRC11CEntityInfoRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4fUiRC9CVector3fRC6CColor"
"__ct__10CExplosionFRC31TLockedToken<20CElectricDescription>9TUniqueIdbRC11CEntityInfoRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4fUiRC9CVector3fRC6CColor": "__ct__10CExplosionFRC36TLockedToken<20CElectricDescription>9TUniqueIdbRC11CEntityInfoRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4fUiRC9CVector3fRC6CColor":
/* 8005A8DC 0005783C 94 21 FF 80 */ stwu r1, -0x80(r1) /* 8005A8DC 0005783C 94 21 FF 80 */ stwu r1, -0x80(r1)
/* 8005A8E0 00057840 7C 08 02 A6 */ mflr r0 /* 8005A8E0 00057840 7C 08 02 A6 */ mflr r0
/* 8005A8E4 00057844 90 01 00 84 */ stw r0, 0x84(r1) /* 8005A8E4 00057844 90 01 00 84 */ stw r0, 0x84(r1)
@ -622,9 +622,9 @@ lbl_8005A8C0:
/* 8005A914 00057874 7F 88 E3 78 */ mr r8, r28 /* 8005A914 00057874 7F 88 E3 78 */ mr r8, r28
/* 8005A918 00057878 B0 01 00 08 */ sth r0, 8(r1) /* 8005A918 00057878 B0 01 00 08 */ sth r0, 8(r1)
/* 8005A91C 0005787C 48 00 04 35 */ bl "__ct__7CEffectF9TUniqueIdRC11CEntityInfobRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4f" /* 8005A91C 0005787C 48 00 04 35 */ bl "__ct__7CEffectF9TUniqueIdRC11CEntityInfobRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4f"
/* 8005A920 00057880 3C 80 80 3E */ lis r4, lbl_803DA0A8@ha /* 8005A920 00057880 3C 80 80 3E */ lis r4, __vt__10CExplosion@ha
/* 8005A924 00057884 3C 60 80 3D */ lis r3, lbl_803CCF78@ha /* 8005A924 00057884 3C 60 80 3D */ lis r3, lbl_803CCF78@ha
/* 8005A928 00057888 38 04 A0 A8 */ addi r0, r4, lbl_803DA0A8@l /* 8005A928 00057888 38 04 A0 A8 */ addi r0, r4, __vt__10CExplosion@l
/* 8005A92C 0005788C 3B 00 00 00 */ li r24, 0 /* 8005A92C 0005788C 3B 00 00 00 */ li r24, 0
/* 8005A930 00057890 90 1A 00 00 */ stw r0, 0(r26) /* 8005A930 00057890 90 1A 00 00 */ stw r0, 0(r26)
/* 8005A934 00057894 38 83 CF 78 */ addi r4, r3, lbl_803CCF78@l /* 8005A934 00057894 38 83 CF 78 */ addi r4, r3, lbl_803CCF78@l
@ -767,9 +767,9 @@ lbl_8005AADC:
/* 8005AB30 00057A90 7F 88 E3 78 */ mr r8, r28 /* 8005AB30 00057A90 7F 88 E3 78 */ mr r8, r28
/* 8005AB34 00057A94 B0 01 00 08 */ sth r0, 8(r1) /* 8005AB34 00057A94 B0 01 00 08 */ sth r0, 8(r1)
/* 8005AB38 00057A98 48 00 02 19 */ bl "__ct__7CEffectF9TUniqueIdRC11CEntityInfobRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4f" /* 8005AB38 00057A98 48 00 02 19 */ bl "__ct__7CEffectF9TUniqueIdRC11CEntityInfobRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4f"
/* 8005AB3C 00057A9C 3C 80 80 3E */ lis r4, lbl_803DA0A8@ha /* 8005AB3C 00057A9C 3C 80 80 3E */ lis r4, __vt__10CExplosion@ha
/* 8005AB40 00057AA0 3C 60 80 3D */ lis r3, lbl_803CCF78@ha /* 8005AB40 00057AA0 3C 60 80 3D */ lis r3, lbl_803CCF78@ha
/* 8005AB44 00057AA4 38 04 A0 A8 */ addi r0, r4, lbl_803DA0A8@l /* 8005AB44 00057AA4 38 04 A0 A8 */ addi r0, r4, __vt__10CExplosion@l
/* 8005AB48 00057AA8 3B 00 00 00 */ li r24, 0 /* 8005AB48 00057AA8 3B 00 00 00 */ li r24, 0
/* 8005AB4C 00057AAC 90 1A 00 00 */ stw r0, 0(r26) /* 8005AB4C 00057AAC 90 1A 00 00 */ stw r0, 0(r26)
/* 8005AB50 00057AB0 38 83 CF 78 */ addi r4, r3, lbl_803CCF78@l /* 8005AB50 00057AB0 38 83 CF 78 */ addi r4, r3, lbl_803CCF78@l
@ -873,8 +873,8 @@ lbl_8005AC20:
/* 8005ACC8 00057C28 38 21 00 80 */ addi r1, r1, 0x80 /* 8005ACC8 00057C28 38 21 00 80 */ addi r1, r1, 0x80
/* 8005ACCC 00057C2C 4E 80 00 20 */ blr /* 8005ACCC 00057C2C 4E 80 00 20 */ blr
.global __dt__12CParticleGenFv .global "__dt__Q24rstl52list<Q24rstl10pair<Us,b>,Q24rstl17rmemory_allocator>Fv"
__dt__12CParticleGenFv: "__dt__Q24rstl52list<Q24rstl10pair<Us,b>,Q24rstl17rmemory_allocator>Fv":
/* 8005ACD0 00057C30 94 21 FF E0 */ stwu r1, -0x20(r1) /* 8005ACD0 00057C30 94 21 FF E0 */ stwu r1, -0x20(r1)
/* 8005ACD4 00057C34 7C 08 02 A6 */ mflr r0 /* 8005ACD4 00057C34 7C 08 02 A6 */ mflr r0
/* 8005ACD8 00057C38 90 01 00 24 */ stw r0, 0x24(r1) /* 8005ACD8 00057C38 90 01 00 24 */ stw r0, 0x24(r1)

View File

@ -5032,7 +5032,7 @@ lbl_8007B214:
/* 8007B2FC 0007825C 39 21 00 EC */ addi r9, r1, 0xec /* 8007B2FC 0007825C 39 21 00 EC */ addi r9, r1, 0xec
/* 8007B300 00078260 38 C0 00 01 */ li r6, 1 /* 8007B300 00078260 38 C0 00 01 */ li r6, 1
/* 8007B304 00078264 39 40 00 00 */ li r10, 0 /* 8007B304 00078264 39 40 00 00 */ li r10, 0
/* 8007B308 00078268 4B FD F5 D5 */ bl "__ct__10CExplosionFRC31TLockedToken<20CElectricDescription>9TUniqueIdbRC11CEntityInfoRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4fUiRC9CVector3fRC6CColor" /* 8007B308 00078268 4B FD F5 D5 */ bl "__ct__10CExplosionFRC36TLockedToken<20CElectricDescription>9TUniqueIdbRC11CEntityInfoRCQ24rstl66basic_string<c,Q24rstl14char_traits<c>,Q24rstl17rmemory_allocator>RC12CTransform4fUiRC9CVector3fRC6CColor"
/* 8007B30C 0007826C 7C 7F 1B 78 */ mr r31, r3 /* 8007B30C 0007826C 7C 7F 1B 78 */ mr r31, r3
lbl_8007B310: lbl_8007B310:
/* 8007B310 00078270 7F 40 07 75 */ extsb. r0, r26 /* 8007B310 00078270 7F 40 07 75 */ extsb. r0, r26

View File

@ -76,7 +76,7 @@ LIBS = [
["MetroidPrime/Tweaks/CTweakParticle", True], ["MetroidPrime/Tweaks/CTweakParticle", True],
"MetroidPrime/Clamp_int", "MetroidPrime/Clamp_int",
["MetroidPrime/CArchMsgParmControllerStatus", True], ["MetroidPrime/CArchMsgParmControllerStatus", True],
"MetroidPrime/CExplosion", ["MetroidPrime/CExplosion", False],
["MetroidPrime/CEffect", True], ["MetroidPrime/CEffect", True],
"MetroidPrime/Cameras/CGameCamera", "MetroidPrime/Cameras/CGameCamera",
"MetroidPrime/CGameArea", "MetroidPrime/CGameArea",

View File

@ -23,7 +23,8 @@ public:
void RemoveRef(); void RemoveRef();
CToken& operator=(const CToken&); CToken& operator=(const CToken&);
bool HasReference() const { return x0_objRef != nullptr; } bool HasReference() const { return x0_objRef != nullptr; }
FourCC GetReferenceType() { return x0_objRef->GetTag().type; } const SObjectTag& GetTag() const { return x0_objRef->GetTag(); }
FourCC GetReferenceType() { return GetTag().type; }
bool HasLock() { return x4_lockHeld; } bool HasLock() { return x4_lockHeld; }

View File

@ -0,0 +1,9 @@
#ifndef _CCUBEMODEL
#define _CCUBEMODEL
class CCubeModel {
public:
static void SetRenderModelBlack(bool v);
};
#endif // _CCUBEMODEL

View File

@ -9,6 +9,22 @@
#include "Kyoto/Graphics/CTevCombiners.hpp" #include "Kyoto/Graphics/CTevCombiners.hpp"
enum ERglFogMode {
kRFM_None = GX_FOG_NONE,
kRFM_PerspLin = GX_FOG_PERSP_LIN,
kRFM_PerspExp = GX_FOG_PERSP_EXP,
kRFM_PerspExp2 = GX_FOG_ORTHO_EXP2,
kRFM_PerspRevExp = GX_FOG_PERSP_REVEXP,
kRFM_PerspRevExp2 = GX_FOG_PERSP_REVEXP2,
kRFM_OrthoLin = GX_FOG_ORTHO_LIN,
kRFM_OrthoExp = GX_FOG_ORTHO_EXP,
kRFM_OrthoExp2 = GX_FOG_ORTHO_EXP2,
kRFM_OrthoRevExp = GX_FOG_ORTHO_REVEXP,
kRFM_OrthoRevExp2 = GX_FOG_ORTHO_REVEXP2,
};
enum ERglTevStage { enum ERglTevStage {
kTS_Stage0, kTS_Stage0,
kTS_Stage1, kTS_Stage1,
@ -156,6 +172,7 @@ public:
static void DisableAllLights(); static void DisableAllLights();
static void SetAmbientColor(const CColor&); static void SetAmbientColor(const CColor&);
static void SetFog(ERglFogMode mode, float startz, float endz, const CColor& color);
static void SetModelMatrix(const CTransform4f& xf); static void SetModelMatrix(const CTransform4f& xf);
static void SetAlphaCompare(ERglAlphaFunc comp0, u8 ref0, ERglAlphaOp op, ERglAlphaFunc comp1, static void SetAlphaCompare(ERglAlphaFunc comp0, u8 ref0, ERglAlphaOp op, ERglAlphaFunc comp1,

View File

@ -64,7 +64,7 @@ public:
virtual bool GetParticleEmission() const override; virtual bool GetParticleEmission() const override;
virtual CColor GetModulationColor() const override; virtual CColor GetModulationColor() const override;
virtual bool IsSystemDeletable() const override; virtual bool IsSystemDeletable() const override;
virtual CAABox GetBounds() const override; virtual rstl::optional_object<CAABox> GetBounds() const override;
virtual int GetParticleCount() const override; virtual int GetParticleCount() const override;
virtual bool SystemHasLight() const override; virtual bool SystemHasLight() const override;
virtual CLight GetLight() override; virtual CLight GetLight() override;

View File

@ -31,7 +31,7 @@ public:
bool GetParticleEmission() const override; bool GetParticleEmission() const override;
CColor GetModulationColor() const override; CColor GetModulationColor() const override;
bool IsSystemDeletable() const override; bool IsSystemDeletable() const override;
CAABox GetBounds() const override; rstl::optional_object<CAABox> GetBounds() const override;
int GetParticleCount() const override; int GetParticleCount() const override;
bool SystemHasLight() const override; bool SystemHasLight() const override;
CLight GetLight() override; CLight GetLight() override;

View File

@ -9,6 +9,8 @@
#include "Kyoto/Particles/CWarp.hpp" #include "Kyoto/Particles/CWarp.hpp"
#include "rstl/list.hpp" #include "rstl/list.hpp"
#include "rstl/pair.hpp"
#include "rstl/optional_object.hpp"
class CWarp; class CWarp;
@ -35,7 +37,7 @@ public:
virtual CColor GetModulationColor() const = 0; virtual CColor GetModulationColor() const = 0;
virtual float GetGeneratorRate() const { return 1.f; } virtual float GetGeneratorRate() const { return 1.f; }
virtual bool IsSystemDeletable() const = 0; virtual bool IsSystemDeletable() const = 0;
virtual CAABox GetBounds() const = 0; virtual rstl::optional_object<CAABox> GetBounds() const = 0;
virtual int GetParticleCount() const = 0; virtual int GetParticleCount() const = 0;
virtual bool SystemHasLight() const = 0; virtual bool SystemHasLight() const = 0;
virtual CLight GetLight() = 0; virtual CLight GetLight() = 0;
@ -44,7 +46,7 @@ public:
virtual uint Get4CharId() const = 0; virtual uint Get4CharId() const = 0;
private: private:
rstl::list< CWarp > x4_modifiersList; rstl::list< rstl::pair<ushort, bool> > x4_modifiersList;
}; };
#endif // _CPARTICLEGEN #endif // _CPARTICLEGEN

View File

@ -17,6 +17,10 @@ public:
const CEntityInfo& info, const rstl::string& name, const CTransform4f& xf, uint flags, const CEntityInfo& info, const rstl::string& name, const CTransform4f& xf, uint flags,
const CVector3f& scale, const CColor& color); const CVector3f& scale, const CColor& color);
CExplosion(const TLockedToken< CElectricDescription >& electric, TUniqueId uid, bool active,
const CEntityInfo& info, const rstl::string& name, const CTransform4f& xf, uint flags,
const CVector3f& scale, const CColor& color);
// CEntity // CEntity
~CExplosion() override; ~CExplosion() override;
void Accept(IVisitor& visitor) override; void Accept(IVisitor& visitor) override;
@ -32,10 +36,7 @@ public:
public: public:
rstl::single_ptr< CParticleGen > xe8_particleGen; rstl::single_ptr< CParticleGen > xe8_particleGen;
TUniqueId xec_explosionLight; TUniqueId xec_explosionLight;
union { uint xf0_sourceId;
const CGenDescription* xf0_particleDesc;
const CElectricDescription* xf0_electricDesc;
};
bool xf4_24_renderThermalHot : 1; bool xf4_24_renderThermalHot : 1;
bool xf4_25_ : 1; bool xf4_25_ : 1;
bool xf4_26_renderXray : 1; bool xf4_26_renderXray : 1;

View File

@ -6,6 +6,7 @@
#include "MetroidPrime/TGameTypes.hpp" #include "MetroidPrime/TGameTypes.hpp"
#include "Kyoto/Graphics/CColor.hpp" #include "Kyoto/Graphics/CColor.hpp"
#include "Kyoto/Graphics/CGraphics.hpp"
#include "Kyoto/IObjectStore.hpp" #include "Kyoto/IObjectStore.hpp"
#include "Kyoto/Math/CAABox.hpp" #include "Kyoto/Math/CAABox.hpp"
#include "Kyoto/Math/CTransform4f.hpp" #include "Kyoto/Math/CTransform4f.hpp"
@ -19,23 +20,6 @@
#include "rstl/single_ptr.hpp" #include "rstl/single_ptr.hpp"
#include "rstl/vector.hpp" #include "rstl/vector.hpp"
enum ERglFogMode {
kRFM_None = GX_FOG_NONE,
kRFM_PerspLin = GX_FOG_PERSP_LIN,
kRFM_PerspExp = GX_FOG_PERSP_EXP,
kRFM_PerspExp2 = GX_FOG_ORTHO_EXP2,
kRFM_PerspRevExp = GX_FOG_PERSP_REVEXP,
kRFM_PerspRevExp2 = GX_FOG_PERSP_REVEXP2,
kRFM_OrthoLin = GX_FOG_ORTHO_LIN,
kRFM_OrthoExp = GX_FOG_ORTHO_EXP,
kRFM_OrthoExp2 = GX_FOG_ORTHO_EXP2,
kRFM_OrthoRevExp = GX_FOG_ORTHO_REVEXP,
kRFM_OrthoRevExp2 = GX_FOG_ORTHO_REVEXP2,
};
class IGameArea { class IGameArea {
public: public:
virtual ~IGameArea(); virtual ~IGameArea();

View File

@ -12,7 +12,6 @@
#include "rstl/rc_ptr.hpp" #include "rstl/rc_ptr.hpp"
#include "rstl/string.hpp" #include "rstl/string.hpp"
enum EParticleGenType { kPGT_Normal, kPGT_Auxiliary }; enum EParticleGenType { kPGT_Normal, kPGT_Auxiliary };
class CStateManager; class CStateManager;
@ -37,7 +36,8 @@ public:
virtual void SetGlobalScale(const CVector3f& scale) = 0; virtual void SetGlobalScale(const CVector3f& scale) = 0;
virtual void SetParticleEmission(bool isActive, CStateManager& stateMgr) = 0; virtual void SetParticleEmission(bool isActive, CStateManager& stateMgr) = 0;
virtual bool IsSystemDeletable() const = 0; virtual bool IsSystemDeletable() const = 0;
virtual CAABox GetBounds() const = 0; // This should match CParticleGen::GetBounds result virtual rstl::optional_object< CAABox >
GetBounds() const = 0; // This should match CParticleGen::GetBounds result
virtual bool HasActiveParticles() const = 0; virtual bool HasActiveParticles() const = 0;
virtual void DestroyParticles() = 0; virtual void DestroyParticles() = 0;
virtual bool HasLight() const = 0; virtual bool HasLight() const = 0;

View File

@ -24,7 +24,7 @@ public:
virtual void SetGlobalScale(const CVector3f& scale) override; virtual void SetGlobalScale(const CVector3f& scale) override;
virtual void SetParticleEmission(bool isActive, CStateManager& stateMgr) override; virtual void SetParticleEmission(bool isActive, CStateManager& stateMgr) override;
virtual bool IsSystemDeletable() const override; virtual bool IsSystemDeletable() const override;
virtual CAABox GetBounds() const override; virtual rstl::optional_object<CAABox> GetBounds() const override;
virtual bool HasActiveParticles() const override; virtual bool HasActiveParticles() const override;
virtual void DestroyParticles() override; virtual void DestroyParticles() override;
virtual bool HasLight() const override; virtual bool HasLight() const override;

View File

@ -226,6 +226,9 @@ public:
void InformListeners(const CVector3f&, EListenNoiseType); void InformListeners(const CVector3f&, EListenNoiseType);
// Fog
void SetupFogForArea(TAreaId area) const;
// //
void ShowPausedHUDMemo(CAssetId strg, float time); void ShowPausedHUDMemo(CAssetId strg, float time);
void QueueMessage(int frameCount, CAssetId msg, float f1); void QueueMessage(int frameCount, CAssetId msg, float f1);

View File

@ -26,11 +26,9 @@ public:
, x10_empty_next(reinterpret_cast< node* >(&xc_empty_prev)) , x10_empty_next(reinterpret_cast< node* >(&xc_empty_prev))
, x14_count(0) {} , x14_count(0) {}
~list(); ~list();
void push_back(const T& val) { do_insert_before(x8_end, val); } void push_back(const T& val) { do_insert_before(x8_end, val); }
void clear() { void clear() { erase(begin(), end()); }
erase(begin(), end());
}
size_t size() const { return x14_count; } size_t size() const { return x14_count; }
bool empty() const { return x14_count == 0; } bool empty() const { return x14_count == 0; }
@ -56,9 +54,7 @@ private:
uchar x8_item[sizeof(T)]; uchar x8_item[sizeof(T)];
node(node* prev, node* next) : x0_prev(prev), x4_next(next) {} node(node* prev, node* next) : x0_prev(prev), x4_next(next) {}
~node() { ~node() { get_value()->~T(); }
get_value()->~T();
}
node* get_prev() const { return x0_prev; } node* get_prev() const { return x0_prev; }
node* get_next() const { return x4_next; } node* get_next() const { return x4_next; }
@ -152,17 +148,17 @@ private:
int x14_count; int x14_count;
}; };
template < typename T, typename Alloc> template < typename T, typename Alloc >
list<T, Alloc>::~list() { list< T, Alloc >::~list() {
node* cur = x4_start; node* cur = x4_start;
while (cur != x8_end) { while (cur != x8_end) {
node* it = cur; node* it = cur;
node* next = cur->get_next(); node* next = cur->get_next();
cur = next; cur = next;
destroy(it); destroy(it);
x0_allocator.deallocate(it); x0_allocator.deallocate(it);
}
} }
}
} // namespace rstl } // namespace rstl

View File

@ -103,7 +103,6 @@ public:
assign(other); assign(other);
return *this; return *this;
} }
basic_string operator+(const basic_string&);
basic_string operator+(const _CharTp*); basic_string operator+(const _CharTp*);
const char* data() const { return x0_ptr; } const char* data() const { return x0_ptr; }

View File

@ -0,0 +1,156 @@
#include "MetroidPrime/CExplosion.hpp"
#include "MetroidPrime/CGameLight.hpp"
#include "MetroidPrime/CStateManager.hpp"
#include "MetroidPrime/Player/CPlayerState.hpp"
#include "Kyoto/Graphics/CCubeModel.hpp"
#include "Kyoto/Graphics/CGraphics.hpp"
#include "Kyoto/Math/CFrustumPlanes.hpp"
#include "Kyoto/Particles/CElementGen.hpp"
#include "Kyoto/Particles/CGenDescription.hpp"
#include "Kyoto/Particles/CParticleElectric.hpp"
#include "MetaRender/CCubeRenderer.hpp"
CExplosion::CExplosion(const TLockedToken< CGenDescription >& particle, TUniqueId uid, bool active,
const CEntityInfo& info, const rstl::string& name, const CTransform4f& xf,
uint flags, const CVector3f& scale, const CColor& color)
: CEffect(uid, info, active, name, xf)
, xe8_particleGen(new CElementGen(TToken< CGenDescription >(particle), CElementGen::kMOT_Normal,
flags & 0x2 ? CElementGen::kOSF_Two : CElementGen::kOSF_One))
, xec_explosionLight(kInvalidUniqueId)
, xf0_sourceId(CToken(particle).GetTag().id)
, xf4_24_renderThermalHot(flags & 0x4)
, xf4_25_(true)
, xf4_26_renderXray(flags & 0x8)
, xf8_time(0.0f) {
SetThermalFlags(flags & 0x1 ? kTF_Cold : kTF_Hot);
xe8_particleGen->SetGlobalTranslation(xf.GetTranslation());
xe8_particleGen->SetOrientation(xf.GetRotation());
xe8_particleGen->SetGlobalScale(scale);
xe8_particleGen->SetModulationColor(color);
}
CExplosion::CExplosion(const TLockedToken< CElectricDescription >& electric, TUniqueId uid,
bool active, const CEntityInfo& info, const rstl::string& name,
const CTransform4f& xf, uint flags, const CVector3f& scale,
const CColor& color)
: CEffect(uid, info, active, name, xf)
, xe8_particleGen(new CParticleElectric(electric))
, xec_explosionLight(kInvalidUniqueId)
, xf0_sourceId(CToken(electric).GetTag().id)
, xf4_24_renderThermalHot(flags & 0x4)
, xf4_25_(true)
, xf4_26_renderXray(flags & 0x8)
// , xf8_time(0.0f)
{
SetThermalFlags(flags & 0x1 ? kTF_Cold : kTF_Hot);
xe8_particleGen->SetGlobalTranslation(xf.GetTranslation());
xe8_particleGen->SetOrientation(xf.GetRotation());
xe8_particleGen->SetGlobalScale(scale);
xe8_particleGen->SetModulationColor(color);
}
CExplosion::~CExplosion() {}
void CExplosion::AddToRenderer(const CFrustumPlanes& frustum, const CStateManager& mgr) const {
if (GetPreRenderClipped()) {
return;
}
if ((xf4_24_renderThermalHot && mgr.GetThermalDrawFlag() == kTD_Hot) ||
(xf4_26_renderXray && mgr.GetPlayerState()->GetActiveVisor(mgr) == CPlayerState::kPV_XRay)) {
EnsureRendered(mgr);
} else {
gpRender->AddParticleGen(*xe8_particleGen);
}
}
void CExplosion::PreRender(CStateManager& mgr, const CFrustumPlanes& frustum) {
CActor::PreRender(mgr, frustum);
SetPreRenderClipped(!xf4_25_ || !frustum.BoxInFrustumPlanes(GetRenderBoundsCached()));
}
void CExplosion::Think(float dt, CStateManager& mgr) {
if (GetTransformDirtySpare()) {
xe8_particleGen->SetGlobalTranslation(GetTranslation());
xe8_particleGen->SetOrientation(GetTransform().GetRotation());
SetTransformDirtySpare(false);
}
xe8_particleGen->Update(dt);
if (xec_explosionLight != kInvalidUniqueId) {
CGameLight* light = TCastToPtr< CGameLight >(mgr.ObjectById(xec_explosionLight));
if (light && GetActive())
light->SetLight(xe8_particleGen->GetLight());
}
xf8_time += dt;
if (xf8_time > 15.f) {
mgr.FreeScriptObject(GetUniqueId());
} else if (xe8_particleGen->IsSystemDeletable()) {
mgr.FreeScriptObject(GetUniqueId());
}
}
void CExplosion::Accept(IVisitor& visitor) { visitor.Visit(*this); }
void CExplosion::AcceptScriptMsg(EScriptObjectMessage msg, TUniqueId sender, CStateManager& mgr) {
switch (msg) {
case kSM_Registered:
if (xe8_particleGen->SystemHasLight()) {
xec_explosionLight = mgr.AllocateUniqueId();
uint sourceId = xf0_sourceId;
mgr.AddObject(new CGameLight(xec_explosionLight, GetCurrentAreaId(), GetActive(),
rstl::string_l("ExplodePLight_") + GetDebugName(),
GetTransform(), GetUniqueId(), xe8_particleGen->GetLight(),
sourceId, 1, 0.f));
}
break;
case kSM_Deleted:
if (xec_explosionLight != kInvalidUniqueId) {
mgr.FreeScriptObject(xec_explosionLight);
xec_explosionLight = kInvalidUniqueId;
}
break;
default:
break;
}
CActor::AcceptScriptMsg(msg, sender, mgr);
if (xec_explosionLight != kInvalidUniqueId)
mgr.SendScriptMsgAlways(sender, xec_explosionLight, msg);
}
void CExplosion::CalculateRenderBounds() {
rstl::optional_object< CAABox > bounds = xe8_particleGen->GetBounds();
if (bounds) {
SetRenderBounds(*bounds);
xf4_25_ = true;
} else {
xf4_25_ = false;
CVector3f pos = GetTransform().GetTranslation();
SetRenderBounds(CAABox(pos, pos));
}
}
void CExplosion::Render(const CStateManager& mgr) const {
if (mgr.GetThermalDrawFlag() == kTD_Hot && xf4_24_renderThermalHot) {
CElementGen::SetSubtractBlend(true);
CCubeModel::SetRenderModelBlack(true);
xe8_particleGen->Render();
CCubeModel::SetRenderModelBlack(false);
CElementGen::SetSubtractBlend(false);
return;
}
CElementGen::SetSubtractBlend(!xf4_24_renderThermalHot);
CGraphics::SetFog(kRFM_PerspLin, 0.f, 75.f, CColor::Black());
xe8_particleGen->Render();
mgr.SetupFogForArea(GetCurrentAreaId());
CElementGen::SetSubtractBlend(false);
}
// bool CExplosion::CanRenderUnsorted(const CStateManager&) const { return false; }

View File

@ -125,6 +125,6 @@ bool CParticleGenInfoGeneric::HasActiveParticles() const {
return x84_system->GetParticleCount() > 0; return x84_system->GetParticleCount() > 0;
} }
CAABox CParticleGenInfoGeneric::GetBounds() const { return x84_system->GetBounds(); } rstl::optional_object<CAABox> CParticleGenInfoGeneric::GetBounds() const { return x84_system->GetBounds(); }
bool CParticleGenInfoGeneric::IsSystemDeletable() const { return x84_system->IsSystemDeletable(); } bool CParticleGenInfoGeneric::IsSystemDeletable() const { return x84_system->IsSystemDeletable(); }

View File

@ -154,10 +154,11 @@ void CScriptPickup::Touch(CActor& act, CStateManager& mgr) {
if (x27c_pickupParticleDesc) { if (x27c_pickupParticleDesc) {
if (mgr.GetPlayerState()->GetActiveVisor(mgr) != CPlayerState::kPV_Thermal) { if (mgr.GetPlayerState()->GetActiveVisor(mgr) != CPlayerState::kPV_Thermal) {
mgr.AddObject(new CExplosion( mgr.AddObject(new CExplosion(
*x27c_pickupParticleDesc, mgr.AllocateUniqueId(), true, TLockedToken< CGenDescription >(*x27c_pickupParticleDesc), mgr.AllocateUniqueId(), true,
CEntityInfo(GetCurrentAreaId(), CEntity::NullConnectionList, kInvalidEditorId), CEntityInfo(GetCurrentAreaId(), CEntity::NullConnectionList, kInvalidEditorId),
rstl::string_l("Explosion - Pickup Effect"), GetTransform(), 0, rstl::string_l("Explosion - Pickup Effect"), GetTransform(), 0,
CVector3f(1.f, 1.f, 1.f), CColor::White())); CVector3f(1.f, 1.f, 1.f), CColor::White()));
} }
} }