From 05f841a5ced04dda08b9225625c383dd7e978c0b Mon Sep 17 00:00:00 2001 From: Phillip Stephens Date: Tue, 1 Feb 2022 01:18:42 -0800 Subject: [PATCH] More CModel RE --- Runtime/Graphics/CCubeModel.cpp | 71 +++++++++++++++++++++++++++------ Runtime/Graphics/CCubeModel.hpp | 56 +++++++++++++++++++++----- 2 files changed, 105 insertions(+), 22 deletions(-) diff --git a/Runtime/Graphics/CCubeModel.cpp b/Runtime/Graphics/CCubeModel.cpp index 5147b2707..d4dc0552d 100644 --- a/Runtime/Graphics/CCubeModel.cpp +++ b/Runtime/Graphics/CCubeModel.cpp @@ -3,6 +3,9 @@ #include "CGraphics.hpp" namespace metaforce { + +#pragma region CModel +u32 CModel::sTotalMemory = 0; u32 CModel::sFrameCounter = 0; bool CModel::sIsTextureTimeoutEnabled = true; CModel* CModel::sThisFrameList = nullptr; @@ -20,9 +23,12 @@ static const u8* MemoryFromPartData(const u8*& dataCur, const u32*& secSizeCur) } CModel::CModel(std::unique_ptr in, u32 dataLen, IObjectStore* store) -: x0_data(std::move(in)), x4_dataLen(dataLen), x34_next(sThisFrameList), x38_lastFrame(CGraphics::GetFrameCounter() - 2) { +: x0_data(std::move(in)) +, x4_dataLen(dataLen) +, x34_next(sThisFrameList) +, x38_lastFrame(CGraphics::GetFrameCounter() - 2) { const u8* data = reinterpret_cast(x0_data.get()); - u32 uVar1 = *reinterpret_cast(data + 8); + u32 flags = *reinterpret_cast(data + 8); u32 sectionSizeStart = 0x2c; if (hecl::SBig(*reinterpret_cast(data + 4)) == 1) { sectionSizeStart = 0x28; @@ -32,29 +38,60 @@ CModel::CModel(std::unique_ptr in, u32 dataLen, IObjectStore* store) if (hecl::SBig(*reinterpret_cast(data + 4)) > 1) { numMatSets = hecl::SBig(*reinterpret_cast(data + 0x28)); } - const auto* dataCur = data + ROUND_UP_32(sectionSizeStart + hecl::SBig(*reinterpret_cast(data + 0x24)) * 4); + const u8* dataCur = data + ROUND_UP_32(sectionSizeStart + hecl::SBig(*reinterpret_cast(data + 0x24)) * 4); x18_matSets.reserve(numMatSets); for (s32 i = 0; i < numMatSets; ++i) { x18_matSets.emplace_back(static_cast(MemoryFromPartData(dataCur, secSizeCur))); auto shader = x18_matSets.back(); CCubeModel::MakeTexturesFromMats(shader.x10_data, shader.x0_textures, true); + x4_dataLen += shader.x0_textures.size() * sizeof(TCachedToken); } + + const u8* positions = MemoryFromPartData(dataCur, secSizeCur); + const u8* normals = MemoryFromPartData(dataCur, secSizeCur); + const u8* vtxColors = MemoryFromPartData(dataCur, secSizeCur); + const u8* floatUVs = MemoryFromPartData(dataCur, secSizeCur); + const u8* shortUVs = nullptr; + if (((flags >> 2) & 1) != 0) { + shortUVs = MemoryFromPartData(dataCur, secSizeCur); + } + + const u8* surfaceInfo = MemoryFromPartData(dataCur, secSizeCur); + u32 surfaceCount = hecl::SBig(*reinterpret_cast(surfaceInfo)); + x8_surfaces.reserve(surfaceCount); + + for (u32 i = 0; i < surfaceCount; ++i) { + // Implement CCubeSurface loading taking into account endian + } + + // TODO: need to endian swap the values + const auto* aabox = reinterpret_cast(data + 12); + x28_modelInst = + std::make_unique(&x8_surfaces, &x18_matSets[0].x0_textures, x18_matSets[0].x10_data, positions, + normals, vtxColors, floatUVs, shortUVs, aabox, flags, true, -1); + + sThisFrameList = this; + if (x34_next != nullptr) { + x34_next->x30_prev = this; + } + x4_dataLen += x8_surfaces.size() * 4; + sTotalMemory += x4_dataLen; + // DCFlushRange(x0_data, dataLen); } void CModel::UpdateLastFrame() { x38_lastFrame = CGraphics::GetFrameCounter(); } void CModel::MoveToThisFrameList() { UpdateLastFrame(); - CModel* ptr = sThisFrameList; - if (sThisFrameList != this) { - RemoveFromList(); - if (sThisFrameList != nullptr) { - x34_next = sThisFrameList; - x34_next->x30_prev = this; - } - ptr = this; + if (sThisFrameList == this) { + return; } - sThisFrameList = ptr; + if (sThisFrameList != nullptr) { + x34_next = sThisFrameList; + x34_next->x30_prev = this; + } + + sThisFrameList = this; } void CModel::RemoveFromList() { @@ -101,4 +138,14 @@ void CModel::FrameDone() { void CModel::EnableTextureTimeout() { sIsTextureTimeoutEnabled = true; } void CModel::DisableTextureTimeout() { sIsTextureTimeoutEnabled = false; } +#pragma endregion + +#pragma region CCubeModel + +void CCubeModel::UnlockTextures() {} + +void CCubeModel::MakeTexturesFromMats(const u8* ptr, std::vector>& texture, bool b1) {} + +#pragma endregion + } // namespace metaforce diff --git a/Runtime/Graphics/CCubeModel.hpp b/Runtime/Graphics/CCubeModel.hpp index 7613a9537..28a8e1400 100644 --- a/Runtime/Graphics/CCubeModel.hpp +++ b/Runtime/Graphics/CCubeModel.hpp @@ -10,25 +10,22 @@ namespace metaforce { class CCubeSurface; -class CCubeModel { -public: - void UnlockTextures() {} - - static void MakeTexturesFromMats(const u8* ptr, std::vector>& texture, bool b1) {} -}; +class CCubeModel; +#pragma region CModel class CModel { public: struct SShader { std::vector> x0_textures; const u8* x10_data; - SShader(const u8* data) : x10_data(data) {} + explicit SShader(const u8* data) : x10_data(data) {} - void UnlockTextures() {}; + void UnlockTextures(){}; }; private: + static u32 sTotalMemory; static u32 sFrameCounter; static bool sIsTextureTimeoutEnabled; static CModel* sThisFrameList; @@ -39,7 +36,7 @@ private: u32 x4_dataLen; std::vector x8_surfaces; std::vector x18_matSets; - CCubeModel* x28_modelInst = nullptr; + std::unique_ptr x28_modelInst = nullptr; u16 x2c_ = 0; u16 x2e_ = 0; CModel* x30_prev = nullptr; @@ -52,9 +49,48 @@ public: void UpdateLastFrame(); void MoveToThisFrameList(); void RemoveFromList(); - void VerifyCurrentShader(s32 idx) {}; + void VerifyCurrentShader(s32 idx){}; static void FrameDone(); static void EnableTextureTimeout(); static void DisableTextureTimeout(); }; + +#pragma endregion + +#pragma region CCubeModel +class CCubeModel { +public: + CCubeModel(const std::vector* surfaces, const std::vector>* textures, + const u8* materialData, const u8* positions, const u8* normals, const u8* vtxColors, const u8* floatUvs, + const u8* shortUVs, const zeus::CAABox* aabox, u8 flags, bool b1, u32 w1) {} + + void UnlockTextures(); + + static void MakeTexturesFromMats(const u8* ptr, std::vector>& texture, bool b1); +}; +#pragma endregion + +#pragma region CCubeSurface +class CCubeSurface { +public: + enum class ECookie { + + }; + +public: + bool IsValid() const; + static CCubeSurface* FromCookieValue(u32); + void GetCookie(ECookie cookie); + void SetCookie(ECookie cookie, u32 value); + u32 GetCookieValue() const; + s32 GetMaterialIndex() const; + s32 GetDisplayListSize() const; + u8* GetDisplayList() const; + u32 GetSurfaceHeaderSize() const; + zeus::CVector3f GetCenter() const; + u32 GetNormalHint() const; + zeus::CAABox GetBounds() const; +}; +#pragma endregion + } // namespace metaforce