mirror of https://github.com/AxioDL/metaforce.git
prelim CDecal imps
This commit is contained in:
parent
76a6b51d14
commit
cedf3dba4e
|
@ -0,0 +1,43 @@
|
||||||
|
#include "CDecal.hpp"
|
||||||
|
|
||||||
|
namespace urde
|
||||||
|
{
|
||||||
|
|
||||||
|
CDecal::CDecal(const TToken<CDecalDescription>& desc, const zeus::CTransform& xf)
|
||||||
|
: x0_description(desc),
|
||||||
|
xc_transform(xf),
|
||||||
|
x3c_decalQuad1(0, 0.f),
|
||||||
|
x48_decalQuad2(0, 0.f)
|
||||||
|
{
|
||||||
|
CGlobalRandom gr(sDecalRandom);
|
||||||
|
|
||||||
|
InitQuad(x3c_decalQuad1, x0_description.GetObj()->x0_Quad);
|
||||||
|
InitQuad(x48_decalQuad2, x0_description.GetObj()->x1c_Quad);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CDecal::InitQuad(CDecal::CQuadDecal& quad, const CDecalDescription::SQuadDescr& desc)
|
||||||
|
{
|
||||||
|
if (desc.x14_TEX)
|
||||||
|
{
|
||||||
|
if (desc.x0_LFT)
|
||||||
|
desc.x0_LFT->GetValue(0, quad.x4_lifetime);
|
||||||
|
else
|
||||||
|
quad.x4_lifetime = 0x7FFFFF;
|
||||||
|
if (desc.x8_ROT)
|
||||||
|
{
|
||||||
|
desc.x8_ROT->GetValue(0, quad.x8_rotation);
|
||||||
|
u32 r0 = (quad._dummy >> 25) & 1;
|
||||||
|
r0 &= desc.x8_ROT->IsConstant();
|
||||||
|
quad._dummy = (quad._dummy & ~0x80) | ((r0 << 7) & 0x80);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (desc.x4_SZE)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
quad.x0_24_ = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,61 @@
|
||||||
|
#ifndef __URDE_CDECAL_HPP__
|
||||||
|
#define __URDE_CDECAL_HPP__
|
||||||
|
|
||||||
|
#include "RetroTypes.hpp"
|
||||||
|
#include "CToken.hpp"
|
||||||
|
#include "zeus/CTransform.hpp"
|
||||||
|
#include "CDecalDescription.hpp"
|
||||||
|
#include "CRandom16.hpp"
|
||||||
|
|
||||||
|
namespace urde
|
||||||
|
{
|
||||||
|
class CDecal
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
struct CQuadDecal
|
||||||
|
{
|
||||||
|
union
|
||||||
|
{
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
bool x0_24_ : 1;
|
||||||
|
};
|
||||||
|
u32 _dummy = 0;
|
||||||
|
};
|
||||||
|
s32 x4_lifetime = 0;
|
||||||
|
float x8_rotation = 0.f;
|
||||||
|
CQuadDecal(s32 i, float f)
|
||||||
|
: x4_lifetime(i),
|
||||||
|
x8_rotation(f)
|
||||||
|
{
|
||||||
|
x0_24_ = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
private:
|
||||||
|
static bool sMoveRedToAphaBuffer;
|
||||||
|
static CRandom16 sDecalRandom;
|
||||||
|
|
||||||
|
TLockedToken<CDecalDescription> x0_description;
|
||||||
|
zeus::CTransform xc_transform;
|
||||||
|
CQuadDecal x3c_decalQuad1;
|
||||||
|
CQuadDecal x48_decalQuad2;
|
||||||
|
u32 x54_ = 0;
|
||||||
|
u32 x58_ = 0;
|
||||||
|
u32 x5c_ = 0;
|
||||||
|
zeus::CVector3f x60_;
|
||||||
|
void InitQuad(CQuadDecal&, const CDecalDescription::SQuadDescr&);
|
||||||
|
public:
|
||||||
|
CDecal(const TToken<CDecalDescription>&, const zeus::CTransform&);
|
||||||
|
bool IsDone() const;
|
||||||
|
void RenderQuad(CQuadDecal&, const CDecalDescription::SQuadDescr&) const;
|
||||||
|
void RenderMdl() const;
|
||||||
|
void ProcessQuad(CQuadDecal&, const CDecalDescription::SQuadDescr&, s32) const;
|
||||||
|
void Update(float);
|
||||||
|
void CheckTime(s32, s32);
|
||||||
|
|
||||||
|
static void SetGlobalSeed(u16);
|
||||||
|
static void SetMoveRedToAlphaBuffer(bool);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // __URDE_CDECAL_HPP__
|
|
@ -1,5 +1,4 @@
|
||||||
#include "CDecalDataFactory.hpp"
|
#include "CDecalDataFactory.hpp"
|
||||||
#include "CDecalDescription.hpp"
|
|
||||||
#include "CGenDescription.hpp"
|
#include "CGenDescription.hpp"
|
||||||
#include "CSwooshDescription.hpp"
|
#include "CSwooshDescription.hpp"
|
||||||
#include "CElectricDescription.hpp"
|
#include "CElectricDescription.hpp"
|
||||||
|
@ -102,7 +101,8 @@ bool CDecalDataFactory::CreateDPSM(CDecalDescription* desc, CInputStream& in, CS
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CDecalDataFactory::GetQuadDecalInfo(CInputStream& in, CSimplePool* resPool, FourCC clsId, SQuadDescr& quad)
|
void CDecalDataFactory::GetQuadDecalInfo(CInputStream& in, CSimplePool* resPool, FourCC clsId,
|
||||||
|
CDecalDescription::SQuadDescr& quad)
|
||||||
{
|
{
|
||||||
switch (clsId)
|
switch (clsId)
|
||||||
{
|
{
|
||||||
|
|
|
@ -6,19 +6,17 @@
|
||||||
#include "IObj.hpp"
|
#include "IObj.hpp"
|
||||||
#include "CToken.hpp"
|
#include "CToken.hpp"
|
||||||
#include "IOStreams.hpp"
|
#include "IOStreams.hpp"
|
||||||
|
#include "CDecalDescription.hpp"
|
||||||
|
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
struct SQuadDescr;
|
|
||||||
class CDecalDescription;
|
|
||||||
class CSimplePool;
|
class CSimplePool;
|
||||||
|
|
||||||
class CDecalDataFactory
|
class CDecalDataFactory
|
||||||
{
|
{
|
||||||
static bool CreateDPSM(CDecalDescription* desc,CInputStream& in,CSimplePool* resPool);
|
static bool CreateDPSM(CDecalDescription* desc,CInputStream& in,CSimplePool* resPool);
|
||||||
static CDecalDescription* CreateGeneratorDescription(CInputStream& in, CSimplePool* resPool);
|
static CDecalDescription* CreateGeneratorDescription(CInputStream& in, CSimplePool* resPool);
|
||||||
static void GetQuadDecalInfo(CInputStream& in, CSimplePool* resPool, FourCC clsId, SQuadDescr& quad);
|
static void GetQuadDecalInfo(CInputStream& in, CSimplePool* resPool, FourCC clsId, CDecalDescription::SQuadDescr& quad);
|
||||||
public:
|
public:
|
||||||
static CDecalDescription* GetGeneratorDesc(CInputStream& in,CSimplePool* resPool);
|
static CDecalDescription* GetGeneratorDesc(CInputStream& in,CSimplePool* resPool);
|
||||||
};
|
};
|
||||||
|
|
|
@ -10,8 +10,11 @@
|
||||||
|
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
struct SQuadDescr
|
class CDecalDescription
|
||||||
{
|
{
|
||||||
|
public:
|
||||||
|
struct SQuadDescr
|
||||||
|
{
|
||||||
std::unique_ptr<CIntElement> x0_LFT;
|
std::unique_ptr<CIntElement> x0_LFT;
|
||||||
std::unique_ptr<CRealElement> x4_SZE;
|
std::unique_ptr<CRealElement> x4_SZE;
|
||||||
std::unique_ptr<CRealElement> x8_ROT;
|
std::unique_ptr<CRealElement> x8_ROT;
|
||||||
|
@ -19,11 +22,8 @@ struct SQuadDescr
|
||||||
std::unique_ptr<CColorElement> x10_CLR;
|
std::unique_ptr<CColorElement> x10_CLR;
|
||||||
std::unique_ptr<CUVElement> x14_TEX;
|
std::unique_ptr<CUVElement> x14_TEX;
|
||||||
bool x18_ADD = false;
|
bool x18_ADD = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CDecalDescription
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
SQuadDescr x0_Quad;
|
SQuadDescr x0_Quad;
|
||||||
SQuadDescr x1c_Quad;
|
SQuadDescr x1c_Quad;
|
||||||
SParticleModel x38_DMDL;
|
SParticleModel x38_DMDL;
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#include "CDecalManager.hpp"
|
#include "CDecalManager.hpp"
|
||||||
#include "CDecalDescription.hpp"
|
#include "CDecalDescription.hpp"
|
||||||
|
#include "CDecal.hpp"
|
||||||
|
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
|
|
|
@ -5,18 +5,10 @@
|
||||||
#include "rstl.hpp"
|
#include "rstl.hpp"
|
||||||
#include "optional.hpp"
|
#include "optional.hpp"
|
||||||
#include "CToken.hpp"
|
#include "CToken.hpp"
|
||||||
|
#include "CDecal.hpp"
|
||||||
|
|
||||||
namespace urde
|
namespace urde
|
||||||
{
|
{
|
||||||
|
|
||||||
class CDecal
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
class CQuadDecal
|
|
||||||
{
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
class CDecalManager
|
class CDecalManager
|
||||||
{
|
{
|
||||||
struct SDecal
|
struct SDecal
|
||||||
|
|
|
@ -27,6 +27,7 @@ set(PARTICLE_SOURCES
|
||||||
CParticleElectric.hpp CParticleElectric.cpp
|
CParticleElectric.hpp CParticleElectric.cpp
|
||||||
CParticleGen.hpp CParticleGen.cpp
|
CParticleGen.hpp CParticleGen.cpp
|
||||||
CProjectileWeaponDataFactory.hpp CProjectileWeaponDataFactory.cpp
|
CProjectileWeaponDataFactory.hpp CProjectileWeaponDataFactory.cpp
|
||||||
|
CDecal.hpp CDecal.cpp
|
||||||
CDecalManager.hpp CDecalManager.cpp
|
CDecalManager.hpp CDecalManager.cpp
|
||||||
CSpawnSystemKeyframeData.hpp CSpawnSystemKeyframeData.cpp
|
CSpawnSystemKeyframeData.hpp CSpawnSystemKeyframeData.cpp
|
||||||
CWarp.hpp CWarp.cpp
|
CWarp.hpp CWarp.cpp
|
||||||
|
|
Loading…
Reference in New Issue