d_lyt_meter_shield_gauge OK

This commit is contained in:
robojumper
2025-04-15 22:28:43 +02:00
parent ba4a58df23
commit dab6fe2997
7 changed files with 423 additions and 41 deletions
+341 -10
View File
@@ -1,9 +1,39 @@
#include "d/lyt/meter/d_lyt_meter_shield_gauge.h"
#include "common.h"
#include "d/d_pouch.h"
#include "d/lyt/d2d.h"
#include "d/lyt/d_lyt_meter_configuration.h"
#include "toBeSorted/file_manager.h"
#include "toBeSorted/small_sound_mgr.h"
STATE_DEFINE(dLytMeterShieldGauge_c, Normal);
STATE_DEFINE(dLytMeterShieldGauge_c, Use);
STATE_DEFINE(dLytMeterShieldGauge_c, ToMax);
static const d2d::LytBrlanMapping brlanMap[] = {
{ "shield_00_break.brlan", "G_break_00"},
{ "shield_00_level.brlan", "G_level_00"},
{"shield_00_shieldUpDown.brlan", "G_shield_00"},
{ "shield_00_shieldType.brlan", "G_shieldType_00"},
{ "shield_00_shieldUse.brlan", "G_shield_01"},
{ "shield_00_toMax.brlan", "G_toMax_00"},
{ "shield_00_loop.brlan", "G_loop_00"},
{ "shield_00_loop.brlan", "G_loop_01"},
};
#define SHIELD_ANIM_BREAK 0
#define SHIELD_ANIM_LEVEL 1
#define SHIELD_ANIM_UPDOWN 2
#define SHIELD_ANIM_TYPE 3
#define SHIELD_ANIM_USE 4
#define SHIELD_ANIM_TO_MAX 5
#define SHIELD_ANIM_LOOP_0 6
#define SHIELD_ANIM_LOOP_1 7
#define SHIELD_NUM_ANIMS 8
// Incredible use of the state manager here
void dLytMeterShieldGauge_c::initializeState_Normal() {}
void dLytMeterShieldGauge_c::executeState_Normal() {}
void dLytMeterShieldGauge_c::finalizeState_Normal() {}
@@ -17,31 +47,332 @@ void dLytMeterShieldGauge_c::executeState_ToMax() {}
void dLytMeterShieldGauge_c::finalizeState_ToMax() {}
bool dLytMeterShieldGauge_c::build(d2d::ResAccIf_c *resAcc) {
// TODO
mLyt.setResAcc(resAcc);
mLyt.build("shield_00.brlyt", nullptr);
for (int i = 0; i < SHIELD_NUM_ANIMS; i++) {
mAnm[i].init(brlanMap[i].mFile, resAcc, mLyt.getLayout(), brlanMap[i].mName);
mAnm[i].bind(false);
mAnm[i].setAnimEnable(false);
}
mpOwnerPane = nullptr;
field_0x31D = 1;
field_0x2E0 = 0.0f;
field_0x2E4 = 0.0f;
field_0x2E8 = 0.0f;
field_0x2EC = 0.0f;
field_0x308 = convertFilePouchSlot(FileManager::GetInstance()->getShieldPouchSlot());
field_0x300 = field_0x2EC;
field_0x304 = field_0x2E0;
field_0x2FC = dLytMeterConfiguration_c::GetInstance()->getField_0x1C8();
field_0x2F0 = 80.0f;
field_0x2F4 = 80.0f;
field_0x2F8 = mAnm[SHIELD_ANIM_USE].getAnimDuration() - 1.0f;
field_0x30D = 0;
field_0x30E = 0;
field_0x30C = 0;
field_0x31F = 0;
field_0x31E = 0;
field_0x318 = 0;
field_0x310 = 0;
field_0x314 = -1;
mAnm[SHIELD_ANIM_UPDOWN].setFrame(field_0x2E0);
mAnm[SHIELD_ANIM_UPDOWN].setAnimEnable(true);
field_0x2E4 = calcUpdownRatio(field_0x2E0);
mAnm[SHIELD_ANIM_USE].setFrame(field_0x2F8 - field_0x2E4);
mAnm[SHIELD_ANIM_USE].setAnimEnable(true);
setLevel(field_0x2F0);
mAnm[SHIELD_ANIM_LEVEL].setAnimEnable(true);
mAnm[SHIELD_ANIM_TYPE].setFrame(getLytFrameForShield(0));
mAnm[SHIELD_ANIM_TYPE].setAnimEnable(true);
mAnm[SHIELD_ANIM_LOOP_0].setAnimEnable(true);
mAnm[SHIELD_ANIM_LOOP_1].setAnimEnable(true);
mAnm[SHIELD_ANIM_BREAK].setToEnd();
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(true);
mLyt.calc();
mAnm[SHIELD_ANIM_UPDOWN].setAnimEnable(false);
mAnm[SHIELD_ANIM_LEVEL].setAnimEnable(false);
mAnm[SHIELD_ANIM_TYPE].setAnimEnable(false);
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(false);
field_0x31C = 1;
field_0x30C = 1;
mStateMgr.changeState(StateID_Normal);
return true;
}
bool dLytMeterShieldGauge_c::remove() {
for (int i = 0; i < 8; i++) {
mAnmGroups[i].unbind();
mAnmGroups[i].remove();
mAnm[i].unbind();
mAnm[i].remove();
}
return true;
}
bool dLytMeterShieldGauge_c::execute() {
// TODO
if (!mpOwnerPane) {
return true;
}
if (!mpOwnerPane->IsVisible()) {
return true;
}
if (field_0x2E0 == 0.0f) {
field_0x318 = 2;
}
bool b1 = false;
bool b2 = true;
bool b3 = false;
bool b4 = false;
if (field_0x310 != field_0x314 ||
field_0x308 != convertFilePouchSlot(FileManager::GetInstance()->getShieldPouchSlot())) {
mLyt.findPane("N_alpha_00")->SetVisible(true);
field_0x314 = field_0x310;
mAnm[SHIELD_ANIM_TYPE].setFrame(getLytFrameForShield(field_0x310));
mAnm[SHIELD_ANIM_TYPE].setAnimEnable(true);
mAnm[SHIELD_ANIM_LOOP_0].setFrame(0.0f);
field_0x31D = 1;
b2 = false;
b3 = true;
field_0x2E8 = field_0x2E0;
field_0x308 = convertFilePouchSlot(FileManager::GetInstance()->getShieldPouchSlot());
}
if (field_0x2E0 != field_0x2E8 || field_0x31D) {
if (field_0x2E0 < field_0x2E8) {
f32 f = calcUpdownRatio(field_0x2E0);
field_0x2E8 = field_0x2E0;
mAnm[SHIELD_ANIM_UPDOWN].setFrame(f);
mAnm[SHIELD_ANIM_UPDOWN].setAnimEnable(true);
b1 = true;
if (field_0x31F && field_0x31D) {
field_0x31F = 0;
b1 = false;
}
field_0x31E = 0;
b4 = true;
} else {
b1 = true;
field_0x2EC += 1.0f;
if (field_0x31F && field_0x31D) {
field_0x31F = 0;
b1 = false;
}
if (field_0x2EC >= field_0x2E0 || field_0x31D) {
field_0x2EC = field_0x2E0;
}
if (field_0x2E0 < field_0x2EC) {
field_0x31E = 1;
}
if (!field_0x31D) {
if (field_0x2E0 >= field_0x2F0) {
if (field_0x31E) {
SmallSoundManager::GetInstance()->playSoundWithPitch(SE_S_GAUGE_SHIELD_UP_LV, 1.0f);
}
SmallSoundManager::GetInstance()->playSound(SE_S_GAUGE_SHIELD_UP_MAX);
} else {
if (field_0x31E) {
SmallSoundManager::GetInstance()->playSoundWithPitch(
SE_S_GAUGE_SHIELD_UP_LV, field_0x2E0 / field_0x2F0
);
}
}
}
f32 tmp = calcUpdownRatio(field_0x2EC);
field_0x2E4 = tmp;
if (!field_0x31F) {
mAnm[SHIELD_ANIM_USE].setFrame(field_0x2F8 - field_0x2E4);
mAnm[SHIELD_ANIM_USE].setAnimEnable(true);
}
field_0x2E8 = field_0x2EC;
mAnm[SHIELD_ANIM_UPDOWN].setFrame(tmp);
mAnm[SHIELD_ANIM_UPDOWN].setAnimEnable(true);
}
if (FileManager::GetInstance()->getShieldPouchSlot() == 8) {
if (field_0x2E0 <= 0.0f && b4) {
mAnm[SHIELD_ANIM_BREAK].setFrame(0.0f);
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(true);
field_0x30D = 1;
} else {
mAnm[SHIELD_ANIM_BREAK].setToEnd();
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(true);
mLyt.calc();
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(false);
field_0x30C = 1;
}
} else {
if (field_0x2E0 <= 0.0f && b4) {
mAnm[SHIELD_ANIM_BREAK].setFrame(0.0f);
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(true);
field_0x30D = 1;
} else if (b2 && field_0x2E0 >= field_0x2F0) {
mAnm[SHIELD_ANIM_TO_MAX].setFrame(0.0f);
mAnm[SHIELD_ANIM_TO_MAX].setAnimEnable(true);
field_0x30E = 1;
}
}
}
f32 f1 = dLytMeterConfiguration_c::GetInstance()->getField_0x1CC() * 40.0f / 4.0f;
f32 f2 = dLytMeterConfiguration_c::GetInstance()->getField_0x1D0() * 40.0f / 4.0f;
f32 f3 = dLytMeterConfiguration_c::GetInstance()->getField_0x1C4() * 40.0f / 4.0f;
(void)calcUpdownRatio(field_0x2E0);
if (field_0x31F) {
if (field_0x2E0 < field_0x304 && field_0x2E0 < field_0x2EC - f1) {
field_0x2FC = dLytMeterConfiguration_c::GetInstance()->getField_0x1C8();
field_0x300 = field_0x2EC;
field_0x304 = field_0x2E0;
field_0x2E4 = calcUpdownRatio(field_0x2EC);
mAnm[SHIELD_ANIM_USE].setFrame(field_0x2F8 - field_0x2E4);
mAnm[SHIELD_ANIM_USE].setAnimEnable(true);
} else {
if (field_0x2FC > 0) {
field_0x2FC--;
}
if (field_0x2FC == 0) {
field_0x300 = field_0x300 - f2;
if (field_0x300 < field_0x2E0) {
field_0x31F = 0;
field_0x300 = field_0x2E0;
}
mAnm[SHIELD_ANIM_USE].setAnimEnable(true);
field_0x2E4 = calcUpdownRatio(field_0x300);
mAnm[SHIELD_ANIM_USE].setFrame(field_0x2F8 - field_0x2E4);
}
}
} else if (!field_0x31D && field_0x2E0 < field_0x2EC - f3) {
field_0x31F = 1;
field_0x300 = field_0x2EC;
field_0x304 = field_0x2E0;
field_0x2FC = dLytMeterConfiguration_c::GetInstance()->getField_0x1C8();
field_0x2E4 = calcUpdownRatio(field_0x2EC);
mAnm[SHIELD_ANIM_USE].setFrame(field_0x2F8 - field_0x2E4);
mAnm[SHIELD_ANIM_USE].setAnimEnable(true);
} else if (!b1) {
field_0x2E4 = calcUpdownRatio(field_0x2EC);
mAnm[SHIELD_ANIM_USE].setFrame(field_0x2F8 - field_0x2E4);
mAnm[SHIELD_ANIM_USE].setAnimEnable(true);
}
if (!b1) {
field_0x2EC = field_0x2E0;
}
field_0x31D = 0;
if (field_0x2F0 != field_0x2F4 || b3) {
setLevel(field_0x2F0);
mAnm[SHIELD_ANIM_LEVEL].setAnimEnable(true);
field_0x2F4 = field_0x2F0;
}
if (mAnm[SHIELD_ANIM_BREAK].isEnabled()) {
if (field_0x318 == 0 && field_0x2E0 > 0) {
mAnm[SHIELD_ANIM_BREAK].setFrame(0.0f);
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(true); // redundant?
field_0x30C = 0;
field_0x30D = 0;
} else if (mAnm[SHIELD_ANIM_BREAK].isEndReached()) {
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(false);
field_0x30C = 1;
field_0x30D = 0;
} else {
mAnm[SHIELD_ANIM_BREAK].play();
}
} else if (field_0x30C && !field_0x318 && field_0x2E0 > 0.0f) {
mAnm[SHIELD_ANIM_BREAK].setFrame(0.0f);
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(true);
field_0x30C = 0;
field_0x30D = 0;
}
if (mAnm[SHIELD_ANIM_TO_MAX].isEnabled()) {
if (mAnm[SHIELD_ANIM_TO_MAX].isEndReached()) {
mAnm[SHIELD_ANIM_TO_MAX].setAnimEnable(false);
field_0x30E = 0;
} else {
mAnm[SHIELD_ANIM_TO_MAX].play();
}
}
mStateMgr.executeState();
if ((field_0x314 == 6 || field_0x314 == 7 || field_0x314 == 8) && mAnm[SHIELD_ANIM_USE].getFrame() == 0.0f &&
mAnm[SHIELD_ANIM_LOOP_0].getFrame() == 0.0f) {
if (mAnm[SHIELD_ANIM_LOOP_0].isEnabled()) {
mAnm[SHIELD_ANIM_LOOP_0].setAnimEnable(false);
}
} else if (!mAnm[SHIELD_ANIM_LOOP_0].isEnabled()) {
mAnm[SHIELD_ANIM_LOOP_0].setAnimEnable(true);
}
if (mAnm[SHIELD_ANIM_LOOP_0].isEnabled()) {
mAnm[SHIELD_ANIM_LOOP_0].play();
}
if (mAnm[SHIELD_ANIM_LOOP_1].isEnabled()) {
mAnm[SHIELD_ANIM_LOOP_1].play();
}
mLyt.calc();
if (mAnm[SHIELD_ANIM_UPDOWN].isEnabled()) {
mAnm[SHIELD_ANIM_UPDOWN].setAnimEnable(false);
}
if (mAnm[SHIELD_ANIM_LEVEL].isEnabled()) {
mAnm[SHIELD_ANIM_LEVEL].setAnimEnable(false);
}
if (mAnm[SHIELD_ANIM_TYPE].isEnabled()) {
mAnm[SHIELD_ANIM_TYPE].setAnimEnable(false);
}
if (mAnm[SHIELD_ANIM_USE].isEnabled()) {
mAnm[SHIELD_ANIM_USE].setAnimEnable(false);
}
if (!field_0x30E && mAnm[SHIELD_ANIM_TO_MAX].isEnabled()) {
mAnm[SHIELD_ANIM_TO_MAX].setAnimEnable(false);
}
if (!field_0x30C && !field_0x30D && mAnm[SHIELD_ANIM_BREAK].isEnabled()) {
mAnm[SHIELD_ANIM_BREAK].setAnimEnable(false);
}
if (field_0x318 > 0) {
field_0x318--;
}
return true;
}
const char *dLytMeterShieldGauge_c::getName() const {
return mLyt.getName();
void dLytMeterShieldGauge_c::setLevel(f32 lv) {
mAnm[SHIELD_ANIM_LEVEL].setFrame(lv * 0.5f);
}
d2d::LytBase_c *dLytMeterShieldGauge_c::getLyt() {
return &mLyt;
s32 dLytMeterShieldGauge_c::getLytFrameForShield(s32 shield) const {
static const int table[] = {0, 4, 7, 1, 5, 8, 2, 6, 9, 3};
if (shield == 10) {
shield = 0;
}
return table[shield];
}
nw4r::lyt::Pane *dLytMeterShieldGauge_c::getPane() {
return mLyt.getLayout()->GetRootPane();
f32 dLytMeterShieldGauge_c::calcUpdownRatio(f32 f) const {
f32 duration = mAnm[SHIELD_ANIM_UPDOWN].getAnimDuration() - 1.0f;
f32 bound = 0.0f;
f32 b = (field_0x2F0 > bound ? f / field_0x2F0 : bound);
return b * duration;
}