item_mdl_rupee OK

This commit is contained in:
robojumper
2026-04-30 20:44:33 +02:00
parent b80ede8f48
commit dfb2e9048b
8 changed files with 224 additions and 28 deletions
+4 -1
View File
@@ -1231,20 +1231,23 @@ toBeSorted/item_mdl_item.cpp:
.text start:0x8016F9E0 end:0x8016FE20 align:16
.rodata start:0x804E9650 end:0x804E9A48
.data start:0x80528490 end:0x80528A68
.sdata start:0x80572A28 end:0x80572AA0
.sdata start:0x80572A28 end:0x80572A70
toBeSorted/item_mdl_rupee.cpp:
.text start:0x8016FE20 end:0x80170414 align:16
.rodata start:0x804E9A48 end:0x804E9A80
.data start:0x80528A68 end:0x80528AB0
.sdata start:0x80572A70 end:0x80572A78
toBeSorted/item_mdl_light_fruit.cpp:
.text start:0x80170420 end:0x801708E4 align:16
.data start:0x80528AB0 end:0x80528AE0
.sdata start:0x80572A78 end:0x80572A90
toBeSorted/item_mdl_stamina_fruit.cpp:
.text start:0x801708F0 end:0x80170DA4 align:16
.data start:0x80528AE0 end:0x80528B20
.sdata start:0x80572A90 end:0x80572AA0
toBeSorted/item_spawn.cpp:
.text start:0x80170DB0 end:0x80171AA8 align:16
+11 -11
View File
@@ -9532,16 +9532,16 @@ fn_8016FD80 = .text:0x8016FD80; // type:function size:0x10
fn_8016FD90 = .text:0x8016FD90; // type:function size:0x10
fn_8016FDA0 = .text:0x8016FDA0; // type:function size:0x8
fn_8016FDB0 = .text:0x8016FDB0; // type:function size:0x70
hasItemRupeeModel = .text:0x8016FE20; // type:function size:0x4C
AcItemRupeeModel__init = .text:0x8016FE70; // type:function size:0x2C0
fn_80170130 = .text:0x80170130; // type:function size:0x1C
fn_80170150 = .text:0x80170150; // type:function size:0x48
fn_801701A0 = .text:0x801701A0; // type:function size:0x48
AcItemRupeeModel__draw = .text:0x801701F0; // type:function size:0x40
fn_80170230 = .text:0x80170230; // type:function size:0xAC
fn_801702E0 = .text:0x801702E0; // type:function size:0x48
fn_80170330 = .text:0x80170330; // type:function size:0x48
fn_80170380 = .text:0x80170380; // type:function size:0x94
isMdlForItemId__15dItemMdlRupee_cFUs = .text:0x8016FE20; // type:function size:0x4C
init__15dItemMdlRupee_cFUsP9dAcItem_cP12mAllocator_c = .text:0x8016FE70; // type:function size:0x2C0
vt_0x10__15dItemMdlRupee_cFUc = .text:0x80170130; // type:function size:0x1C
setScale__15dItemMdlRupee_cFRC7mVec3_c = .text:0x80170150; // type:function size:0x48
setLocalMtx__15dItemMdlRupee_cFRC6mMtx_c = .text:0x801701A0; // type:function size:0x48
draw__15dItemMdlRupee_cFv = .text:0x801701F0; // type:function size:0x40
vt_0x20__15dItemMdlRupee_cFUs = .text:0x80170230; // type:function size:0xAC
setPriorityDraw__15dItemMdlRupee_cFv = .text:0x801702E0; // type:function size:0x48
unsetPriorityDraw__15dItemMdlRupee_cFv = .text:0x80170330; // type:function size:0x48
__dt__15dItemMdlRupee_cFv = .text:0x80170380; // type:function size:0x94
IsItemLightFruit = .text:0x80170420; // type:function size:0x10
fn_80170430 = .text:0x80170430; // type:function size:0x214
fn_80170650 = .text:0x80170650; // type:function size:0x1C
@@ -35243,7 +35243,7 @@ lbl_80528A28 = .data:0x80528A28; // type:object size:0xE data:string
ItemModel_vtable = .data:0x80528A38; // type:object size:0x30
lbl_80528A68 = .data:0x80528A68; // type:object size:0x9 data:string
lbl_80528A74 = .data:0x80528A74; // type:object size:0x9 data:string
AcItemRupeeModel__vtable = .data:0x80528A80; // type:object size:0x30
__vt__15dItemMdlRupee_c = .data:0x80528A80; // type:object size:0x30
LightFruitModel_vtable = .data:0x80528AB0; // type:object size:0x30
lbl_80528AE0 = .data:0x80528AE0; // type:object size:0xA data:string
StaminaFruitModel_vtable = .data:0x80528AF0; // type:object size:0x30
+1 -1
View File
@@ -595,7 +595,7 @@ config.libs = [
Object(Matching, "toBeSorted/counters/extra_wallet_counter.cpp"),
Object(Matching, "toBeSorted/item_mdl_misc.cpp"),
Object(NonMatching, "toBeSorted/item_mdl_item.cpp"),
Object(NonMatching, "toBeSorted/item_mdl_rupee.cpp"),
Object(Matching, "toBeSorted/item_mdl_rupee.cpp"),
Object(NonMatching, "toBeSorted/item_mdl_light_fruit.cpp"),
Object(NonMatching, "toBeSorted/item_mdl_stamina_fruit.cpp"),
Object(NonMatching, "toBeSorted/item_spawn.cpp"), # probably multiple files, see sdata2
+1 -2
View File
@@ -1,7 +1,6 @@
#ifndef TOBESORTED_ITEM_MDL_H
#define TOBESORTED_ITEM_MDL_H
#include "m/m3d/m_mdl.h"
#include "m/m_allocator.h"
#include "m/m_mtx.h"
#include "m/m_vec.h"
@@ -21,7 +20,7 @@ public:
/* 0x14 */ virtual void setScale(const mVec3_c &scale) = 0;
/* 0x18 */ virtual void setLocalMtx(const mMtx_c &mtx) = 0;
/* 0x1C */ virtual void draw() = 0;
/* 0x20 */ virtual void vt_0x20() = 0;
/* 0x20 */ virtual void vt_0x20(u16 itemId) = 0;
/* 0x24 */ virtual void setPriorityDraw() = 0;
/* 0x28 */ virtual void unsetPriorityDraw() = 0;
/* 0x2C */ virtual m3d::smdl_c *getMdl() {
+6 -7
View File
@@ -6,7 +6,6 @@
#include "m/m3d/m_anmmdl.h"
#include "m/m3d/m_anmtexpat.h"
#include "m/m3d/m_anmtexsrt.h"
#include "m/m3d/m_mdl.h"
#include "m/m3d/m_smdl.h"
#include "m/types_m.h"
#include "toBeSorted/item_mdl.h"
@@ -19,7 +18,7 @@ public:
/* 0x14 */ virtual void setScale(const mVec3_c &scale) override;
/* 0x18 */ virtual void setLocalMtx(const mMtx_c &mtx) override;
/* 0x1C */ virtual void draw() override;
/* 0x20 */ virtual void vt_0x20() override;
/* 0x20 */ virtual void vt_0x20(u16 itemId) override;
/* 0x24 */ virtual void setPriorityDraw() override;
/* 0x28 */ virtual void unsetPriorityDraw() override;
@@ -61,7 +60,7 @@ public:
/* 0x14 */ virtual void setScale(const mVec3_c &scale) override;
/* 0x18 */ virtual void setLocalMtx(const mMtx_c &mtx) override;
/* 0x1C */ virtual void draw() override;
/* 0x20 */ virtual void vt_0x20() override;
/* 0x20 */ virtual void vt_0x20(u16 itemId) override;
/* 0x24 */ virtual void setPriorityDraw() override;
/* 0x28 */ virtual void unsetPriorityDraw() override;
@@ -103,7 +102,7 @@ public:
/* 0x14 */ virtual void setScale(const mVec3_c &scale) override;
/* 0x18 */ virtual void setLocalMtx(const mMtx_c &mtx) override;
/* 0x1C */ virtual void draw() override;
/* 0x20 */ virtual void vt_0x20() override;
/* 0x20 */ virtual void vt_0x20(u16 itemId) override;
/* 0x24 */ virtual void setPriorityDraw() override;
/* 0x28 */ virtual void unsetPriorityDraw() override;
/* 0x2C */ virtual m3d::smdl_c *getMdl() override {
@@ -145,7 +144,7 @@ public:
/* 0x14 */ virtual void setScale(const mVec3_c &scale) override;
/* 0x18 */ virtual void setLocalMtx(const mMtx_c &mtx) override;
/* 0x1C */ virtual void draw() override;
/* 0x20 */ virtual void vt_0x20() override;
/* 0x20 */ virtual void vt_0x20(u16 itemId) override;
/* 0x24 */ virtual void setPriorityDraw() override;
/* 0x28 */ virtual void unsetPriorityDraw() override;
@@ -174,7 +173,7 @@ public:
/* 0x14 */ virtual void setScale(const mVec3_c &scale) override;
/* 0x18 */ virtual void setLocalMtx(const mMtx_c &mtx) override;
/* 0x1C */ virtual void draw() override;
/* 0x20 */ virtual void vt_0x20() override;
/* 0x20 */ virtual void vt_0x20(u16 itemId) override;
/* 0x24 */ virtual void setPriorityDraw() override;
/* 0x28 */ virtual void unsetPriorityDraw() override;
/* 0x2C */ virtual m3d::smdl_c *getMdl() override;
@@ -195,7 +194,7 @@ public:
/* 0x14 */ virtual void setScale(const mVec3_c &scale) override;
/* 0x18 */ virtual void setLocalMtx(const mMtx_c &mtx) override;
/* 0x1C */ virtual void draw() override;
/* 0x20 */ virtual void vt_0x20() override;
/* 0x20 */ virtual void vt_0x20(u16 itemId) override;
/* 0x24 */ virtual void setPriorityDraw() override;
/* 0x28 */ virtual void unsetPriorityDraw() override;
/* 0x2C */ virtual m3d::smdl_c *getMdl() override;
+36
View File
@@ -0,0 +1,36 @@
#ifndef TOBESORTED_ITEM_MDL_RUPEE_H
#define TOBESORTED_ITEM_MDL_RUPEE_H
#include "m/m3d/m_anmtexpat.h"
#include "m/m3d/m_smdl.h"
#include "toBeSorted/item_mdl.h"
class dItemMdlRupee_c : public dItemMdl_c {
public:
/* 0x08 */ virtual ~dItemMdlRupee_c() {}
/* 0x0C */ virtual bool init(u16 itemId, dAcItem_c *item, mAllocator_c *allocator) override;
/* 0x10 */ virtual void vt_0x10(u8) override;
/* 0x14 */ virtual void setScale(const mVec3_c &scale) override;
/* 0x18 */ virtual void setLocalMtx(const mMtx_c &mtx) override;
/* 0x1C */ virtual void draw() override;
/* 0x20 */ virtual void vt_0x20(u16 itemId) override;
/* 0x24 */ virtual void setPriorityDraw() override;
/* 0x28 */ virtual void unsetPriorityDraw() override;
static bool isMdlForItemId(u16 itemId);
private:
struct MdlConfig {
u16 itemId;
f32 texPatFrame;
};
static const MdlConfig sMdlConfig[];
/* 0x18 */ m3d::smdl_c mMdl1;
/* 0x34 */ m3d::smdl_c mMdl2;
/* 0x50 */ m3d::anmTexPat_c mAnmTexPat1;
/* 0x7C */ m3d::anmTexPat_c mAnmTexPat2;
};
#endif
+6 -6
View File
@@ -275,7 +275,7 @@ void dItemMdlPut_c::draw() {
}
}
void dItemMdlPut_c::vt_0x20() {
void dItemMdlPut_c::vt_0x20(u16 itemId) {
// no-op
}
@@ -539,7 +539,7 @@ void dItemMdlShield_c::draw() {
}
}
void dItemMdlShield_c::vt_0x20() {
void dItemMdlShield_c::vt_0x20(u16 itemId) {
// no-op
}
@@ -795,7 +795,7 @@ void dItemMdlBottle_c::draw() {
}
}
void dItemMdlBottle_c::vt_0x20() {
void dItemMdlBottle_c::vt_0x20(u16 itemId) {
// no-op
}
@@ -937,7 +937,7 @@ void dItemMdlTear_c::draw() {
}
}
void dItemMdlTear_c::vt_0x20() {
void dItemMdlTear_c::vt_0x20(u16 itemId) {
// no-op
}
@@ -1005,7 +1005,7 @@ void dItemMdlFirefly_c::draw() {
mAnmMatClr.play();
}
void dItemMdlFirefly_c::vt_0x20() {
void dItemMdlFirefly_c::vt_0x20(u16 itemId) {
// no-op
}
@@ -1272,7 +1272,7 @@ void dItemMdlPotion_c::draw() {
}
}
void dItemMdlPotion_c::vt_0x20() {
void dItemMdlPotion_c::vt_0x20(u16 itemId) {
// no-op
}
+159
View File
@@ -0,0 +1,159 @@
#include "toBeSorted/item_mdl_rupee.h"
#include "common.h"
#include "d/a/d_a_item.h"
#include "d/a/d_a_itembase.h"
#include "toBeSorted/arc_managers/oarc_manager.h"
const dItemMdlRupee_c::MdlConfig dItemMdlRupee_c::sMdlConfig[] = {
{ ITEM_GREEN_RUPEE, 0.0f},
{ ITEM_BLUE_RUPEE, 1.0f},
{ ITEM_RED_RUPEE, 2.0f},
{ITEM_SILVER_RUPEE, 3.0f},
{ ITEM_GOLD_RUPEE, 4.0f},
{ ITEM_RUPOOR, 5.0f},
{ 0, 0.0f},
};
bool dItemMdlRupee_c::isMdlForItemId(u16 itemId) {
// NON-DETERMINISTIC CODEGEN AAAAAAAAAAAAAAAAAAAAAA
return itemId == ITEM_GREEN_RUPEE || itemId == ITEM_BLUE_RUPEE || itemId == ITEM_RED_RUPEE ||
itemId == ITEM_SILVER_RUPEE || itemId == ITEM_GOLD_RUPEE || itemId == ITEM_RUPOOR;
}
bool dItemMdlRupee_c::init(u16 itemId, dAcItem_c *item, mAllocator_c *allocator) {
if (item == nullptr) {
return false;
}
// no-op
int i = 0;
bool found = false;
while (!found && i < ARRAY_LENGTH(sMdlConfig)) {
if (itemId == sMdlConfig[i].itemId) {
found = true;
} else {
i++;
}
}
if (!found) {
return false;
}
{
void *resData1 = OarcManager::GetInstance()->getMdlFromArc2("PutRupee");
if (resData1 == nullptr) {
return false;
}
nw4r::g3d::ResFile res1(resData1);
if (!res1.IsValid()) {
return false;
}
nw4r::g3d::ResMdl mdl1 = res1.GetResMdl("PutRupee");
if (!mdl1.IsValid()) {
return false;
}
if (!mMdl1.create(mdl1, allocator, 0x123)) {
return false;
}
nw4r::g3d::ResAnmTexPat anmTexPat1 = res1.GetResAnmTexPat("Rupee");
if (!anmTexPat1.IsValid()) {
return false;
}
if (!mAnmTexPat1.create(mdl1, anmTexPat1, allocator, nullptr, 1)) {
return false;
}
mMdl1.setAnm(mAnmTexPat1);
mAnmTexPat1.setFrame(sMdlConfig[i].texPatFrame, 0);
}
{
void *resData2 = OarcManager::GetInstance()->getMdlFromArc2("GetRupee");
if (resData2 == nullptr) {
return false;
}
nw4r::g3d::ResFile res2(resData2);
if (!res2.IsValid()) {
return false;
}
nw4r::g3d::ResMdl mdl2 = res2.GetResMdl("GetRupee");
if (!mdl2.IsValid()) {
return false;
}
if (!mMdl2.create(mdl2, allocator, 0x123)) {
return false;
}
nw4r::g3d::ResAnmTexPat anmTexPat2 = res2.GetResAnmTexPat("Rupee");
if (!anmTexPat2.IsValid()) {
return false;
}
anmTexPat2.Bind(res2);
if (!mAnmTexPat2.create(mdl2, anmTexPat2, allocator, nullptr, 1)) {
return false;
}
mMdl2.setAnm(mAnmTexPat2);
mAnmTexPat2.setFrame(sMdlConfig[i].texPatFrame, 0);
}
mpItem = item;
return true;
}
void dItemMdlRupee_c::vt_0x10(u8 arg) {
if (arg == ITEM_MDL_UNK0x14_3) {
field_0x14 = ITEM_MDL_UNK0x14_1;
} else {
field_0x14 = arg;
}
}
void dItemMdlRupee_c::setScale(const mVec3_c &scale) {
mMdl1.setScale(scale);
mMdl2.setScale(scale);
}
void dItemMdlRupee_c::setLocalMtx(const mMtx_c &mtx) {
mMdl1.setLocalMtx(mtx);
mMdl2.setLocalMtx(mtx);
}
void dItemMdlRupee_c::draw() {
switch (field_0x14) {
case ITEM_MDL_UNK0x14_1: mpItem->fn_8002ECD0(&mMdl1, 7); break;
case ITEM_MDL_UNK0x14_2: mpItem->fn_8002ECD0(&mMdl2, 6); break;
}
}
void dItemMdlRupee_c::vt_0x20(u16 itemId) {
// no-op
int i = 0;
bool found = false;
while (!found && i < ARRAY_LENGTH(sMdlConfig)) {
if (itemId == sMdlConfig[i].itemId) {
found = true;
} else {
i++;
}
}
if (found) {
mAnmTexPat1.setFrame(sMdlConfig[i].texPatFrame, 0);
mAnmTexPat2.setFrame(sMdlConfig[i].texPatFrame, 0);
}
}
void dItemMdlRupee_c::setPriorityDraw() {
mMdl1.setPriorityDraw(0x82, 0x7F);
mMdl2.setPriorityDraw(0x82, 0x7F);
}
void dItemMdlRupee_c::unsetPriorityDraw() {
mMdl1.setPriorityDraw(0x7F, 0x7F);
mMdl2.setPriorityDraw(0x7F, 0x7F);
}