CRippleManager has defeated me

This commit is contained in:
Henrique Gemignani Passos Lima 2022-10-20 03:25:03 +03:00
parent 8e0266da21
commit 3fb706ec17
No known key found for this signature in database
GPG Key ID: E224F951761145F8
4 changed files with 88 additions and 14 deletions

View File

@ -146,9 +146,6 @@ lbl_8011D0F8:
/* 8011D104 0011A064 7C 04 02 14 */ add r0, r4, r0 /* 8011D104 0011A064 7C 04 02 14 */ add r0, r4, r0
/* 8011D108 0011A068 7C 05 00 40 */ cmplw r5, r0 /* 8011D108 0011A068 7C 05 00 40 */ cmplw r5, r0
/* 8011D10C 0011A06C 40 82 FF CC */ bne lbl_8011D0D8 /* 8011D10C 0011A06C 40 82 FF CC */ bne lbl_8011D0D8
.global sub_8011d110
sub_8011d110:
/* 8011D110 0011A070 4E 80 00 20 */ blr /* 8011D110 0011A070 4E 80 00 20 */ blr
.global Init__14CRippleManagerFi .global Init__14CRippleManagerFi
@ -171,7 +168,7 @@ Init__14CRippleManagerFi:
/* 8011D150 0011A0B0 7C 65 1B 78 */ mr r5, r3 /* 8011D150 0011A0B0 7C 65 1B 78 */ mr r5, r3
/* 8011D154 0011A0B4 7F E4 FB 78 */ mr r4, r31 /* 8011D154 0011A0B4 7F E4 FB 78 */ mr r4, r31
/* 8011D158 0011A0B8 38 7E 00 04 */ addi r3, r30, 4 /* 8011D158 0011A0B8 38 7E 00 04 */ addi r3, r30, 4
/* 8011D15C 0011A0BC 48 00 00 49 */ bl sub_8011d1a4 /* 8011D15C 0011A0BC 48 00 00 49 */ bl "resize__Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>FiRC7CRipple"
/* 8011D160 0011A0C0 80 9E 00 10 */ lwz r4, 0x10(r30) /* 8011D160 0011A0C0 80 9E 00 10 */ lwz r4, 0x10(r30)
/* 8011D164 0011A0C4 C0 02 98 F4 */ lfs f0, lbl_805AB614@sda21(r2) /* 8011D164 0011A0C4 C0 02 98 F4 */ lfs f0, lbl_805AB614@sda21(r2)
/* 8011D168 0011A0C8 48 00 00 0C */ b lbl_8011D174 /* 8011D168 0011A0C8 48 00 00 0C */ b lbl_8011D174
@ -192,8 +189,8 @@ lbl_8011D174:
/* 8011D19C 0011A0FC 38 21 00 60 */ addi r1, r1, 0x60 /* 8011D19C 0011A0FC 38 21 00 60 */ addi r1, r1, 0x60
/* 8011D1A0 0011A100 4E 80 00 20 */ blr /* 8011D1A0 0011A100 4E 80 00 20 */ blr
.global sub_8011d1a4 .global "resize__Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>FiRC7CRipple"
sub_8011d1a4: "resize__Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>FiRC7CRipple":
/* 8011D1A4 0011A104 94 21 FF D0 */ stwu r1, -0x30(r1) /* 8011D1A4 0011A104 94 21 FF D0 */ stwu r1, -0x30(r1)
/* 8011D1A8 0011A108 7C 08 02 A6 */ mflr r0 /* 8011D1A8 0011A108 7C 08 02 A6 */ mflr r0
/* 8011D1AC 0011A10C 90 01 00 34 */ stw r0, 0x34(r1) /* 8011D1AC 0011A10C 90 01 00 34 */ stw r0, 0x34(r1)
@ -208,7 +205,7 @@ sub_8011d1a4:
/* 8011D1D0 0011A130 41 82 00 F8 */ beq lbl_8011D2C8 /* 8011D1D0 0011A130 41 82 00 F8 */ beq lbl_8011D2C8
/* 8011D1D4 0011A134 7C 1E 00 00 */ cmpw r30, r0 /* 8011D1D4 0011A134 7C 1E 00 00 */ cmpw r30, r0
/* 8011D1D8 0011A138 40 81 00 B8 */ ble lbl_8011D290 /* 8011D1D8 0011A138 40 81 00 B8 */ ble lbl_8011D290
/* 8011D1DC 0011A13C 48 00 01 55 */ bl sub_8011d330 /* 8011D1DC 0011A13C 48 00 01 55 */ bl "reserve__Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>Fi"
/* 8011D1E0 0011A140 80 9D 00 04 */ lwz r4, 4(r29) /* 8011D1E0 0011A140 80 9D 00 04 */ lwz r4, 4(r29)
/* 8011D1E4 0011A144 80 7D 00 0C */ lwz r3, 0xc(r29) /* 8011D1E4 0011A144 80 7D 00 0C */ lwz r3, 0xc(r29)
/* 8011D1E8 0011A148 54 80 30 32 */ slwi r0, r4, 6 /* 8011D1E8 0011A148 54 80 30 32 */ slwi r0, r4, 6
@ -304,8 +301,8 @@ __ct__14CRippleManagerFif:
/* 8011D328 0011A288 38 21 00 10 */ addi r1, r1, 0x10 /* 8011D328 0011A288 38 21 00 10 */ addi r1, r1, 0x10
/* 8011D32C 0011A28C 4E 80 00 20 */ blr /* 8011D32C 0011A28C 4E 80 00 20 */ blr
.global sub_8011d330 .global "reserve__Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>Fi"
sub_8011d330: "reserve__Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>Fi":
/* 8011D330 0011A290 94 21 FF D0 */ stwu r1, -0x30(r1) /* 8011D330 0011A290 94 21 FF D0 */ stwu r1, -0x30(r1)
/* 8011D334 0011A294 7C 08 02 A6 */ mflr r0 /* 8011D334 0011A294 7C 08 02 A6 */ mflr r0
/* 8011D338 0011A298 90 01 00 34 */ stw r0, 0x34(r1) /* 8011D338 0011A298 90 01 00 34 */ stw r0, 0x34(r1)
@ -340,7 +337,7 @@ lbl_8011D380:
/* 8011D3A4 0011A304 90 C1 00 08 */ stw r6, 8(r1) /* 8011D3A4 0011A304 90 C1 00 08 */ stw r6, 8(r1)
/* 8011D3A8 0011A308 90 01 00 10 */ stw r0, 0x10(r1) /* 8011D3A8 0011A308 90 01 00 10 */ stw r0, 0x10(r1)
/* 8011D3AC 0011A30C 90 01 00 14 */ stw r0, 0x14(r1) /* 8011D3AC 0011A30C 90 01 00 14 */ stw r0, 0x14(r1)
/* 8011D3B0 0011A310 48 00 00 59 */ bl sub_8011d408 /* 8011D3B0 0011A310 48 00 00 59 */ bl "uninitialized_copy<Q24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>,7CRipple>__4rstlFQ24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>Q24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>P7CRipple"
/* 8011D3B4 0011A314 80 1E 00 04 */ lwz r0, 4(r30) /* 8011D3B4 0011A314 80 1E 00 04 */ lwz r0, 4(r30)
/* 8011D3B8 0011A318 80 7E 00 0C */ lwz r3, 0xc(r30) /* 8011D3B8 0011A318 80 7E 00 0C */ lwz r3, 0xc(r30)
/* 8011D3BC 0011A31C 54 00 30 32 */ slwi r0, r0, 6 /* 8011D3BC 0011A31C 54 00 30 32 */ slwi r0, r0, 6
@ -367,8 +364,8 @@ lbl_8011D3EC:
/* 8011D400 0011A360 38 21 00 30 */ addi r1, r1, 0x30 /* 8011D400 0011A360 38 21 00 30 */ addi r1, r1, 0x30
/* 8011D404 0011A364 4E 80 00 20 */ blr /* 8011D404 0011A364 4E 80 00 20 */ blr
.global sub_8011d408 .global "uninitialized_copy<Q24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>,7CRipple>__4rstlFQ24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>Q24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>P7CRipple"
sub_8011d408: "uninitialized_copy<Q24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>,7CRipple>__4rstlFQ24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>Q24rstl106pointer_iterator<7CRipple,Q24rstl43vector<7CRipple,Q24rstl17rmemory_allocator>,Q24rstl17rmemory_allocator>P7CRipple":
/* 8011D408 0011A368 80 63 00 00 */ lwz r3, 0(r3) /* 8011D408 0011A368 80 63 00 00 */ lwz r3, 0(r3)
/* 8011D40C 0011A36C 48 00 00 94 */ b lbl_8011D4A0 /* 8011D40C 0011A36C 48 00 00 94 */ b lbl_8011D4A0
lbl_8011D410: lbl_8011D410:
@ -423,4 +420,3 @@ lbl_803CF318:
# ROM: 0x3CC318 # ROM: 0x3CC318
.asciz "??(??)" .asciz "??(??)"
.balign 4 .balign 4

View File

@ -23,6 +23,13 @@ class CRipple {
public: public:
CRipple(TUniqueId id, const CVector3f& center, float intensity); CRipple(TUniqueId id, const CVector3f& center, float intensity);
TUniqueId GetUniqueId() const { return x0_id; }
float GetTime() const { return x4_time; }
void SetTime(float t) { x4_time = t; }
float GetTimeFalloff() const { return x14_timeFalloff; }
}; };
#endif // _CRIPPLE #endif // _CRIPPLE

View File

@ -1,7 +1,7 @@
#ifndef _CRIPPLEMANAGER #ifndef _CRIPPLEMANAGER
#define _CRIPPLEMANAGER #define _CRIPPLEMANAGER
#include "types.h" #include "MetroidPrime/TGameTypes.hpp"
#include "rstl/vector.hpp" #include "rstl/vector.hpp"
@ -12,6 +12,14 @@ private:
float x0_maxTimeFalloff; float x0_maxTimeFalloff;
rstl::vector< CRipple > x4_ripples; rstl::vector< CRipple > x4_ripples;
float x14_alpha; float x14_alpha;
public:
CRippleManager(int maxRipples, float alpha);
void Init(int maxRipples);
void Update(float dt);
float GetLastRippleDeltaTime(TUniqueId rippler) const;
void AddRipple(const CRipple& ripple);
}; };
#endif // _CRIPPLEMANAGER #endif // _CRIPPLEMANAGER

View File

@ -0,0 +1,63 @@
#include "MetroidPrime/CRippleManager.hpp"
#include "MetroidPrime/CRipple.hpp"
#include "rstl/math.hpp"
CRippleManager::CRippleManager(int maxRipples, float alpha)
: x0_maxTimeFalloff(0.f), x14_alpha(alpha) {
Init(maxRipples);
}
void CRippleManager::Init(int maxRipples) {
x4_ripples.resize(maxRipples, CRipple(kInvalidUniqueId, CVector3f::Zero(), 0.f));
for (rstl::vector< CRipple >::iterator it = x4_ripples.begin(); it != x4_ripples.end(); ++it) {
it->SetTime(9999.f);
}
}
void CRippleManager::Update(float dt) {
for (rstl::vector< CRipple >::iterator it = x4_ripples.begin(); it != x4_ripples.end(); ++it) {
it->SetTime(it->GetTime() + dt);
if (it->GetTime() < 9999.f) {
it->SetTime(9999.f);
}
}
}
float CRippleManager::GetLastRippleDeltaTime(TUniqueId rippler) const {
float res = 9999.f;
for (rstl::vector< CRipple >::const_iterator it = x4_ripples.begin(); it != x4_ripples.end();
++it) {
if (rippler == it->GetUniqueId()) {
if (res > it->GetTime()) {
res = it->GetTime();
}
}
}
return res;
}
void CRippleManager::AddRipple(const CRipple& ripple) {
float maxTime = 0.f;
float itTime;
rstl::vector< CRipple >::iterator t;
rstl::vector< CRipple >::iterator oldestRipple = x4_ripples.end();
rstl::vector< CRipple >::iterator it = x4_ripples.begin();
for (; (t = oldestRipple,
it != x4_ripples.end() && (itTime = it->GetTime(), t = it, itTime != 9999.0f));
++it) {
if (itTime > maxTime) {
oldestRipple = it;
maxTime = itTime;
}
}
if (t != x4_ripples.end()) {
*t = ripple;
x0_maxTimeFalloff = rstl::max_val(x0_maxTimeFalloff, ripple.GetTimeFalloff());
}
}