mirror of
https://github.com/AxioDL/metaforce.git
synced 2025-12-09 15:47:46 +00:00
Add missing factories, update hecl
This commit is contained in:
@@ -12,12 +12,12 @@ static logvisor::Module Log("urde::CParticleSwooshDataFactory");
|
||||
|
||||
using CPF = CParticleDataFactory;
|
||||
|
||||
CSwooshDescription*CParticleSwooshDataFactory::GetGeneratorDesc(CInputStream& in, CSimplePool* resPool)
|
||||
CSwooshDescription* CParticleSwooshDataFactory::GetGeneratorDesc(CInputStream& in, CSimplePool* resPool)
|
||||
{
|
||||
return CreateGeneratorDescription(in, resPool);
|
||||
}
|
||||
|
||||
CSwooshDescription*CParticleSwooshDataFactory::CreateGeneratorDescription(CInputStream& in, CSimplePool* resPool)
|
||||
CSwooshDescription* CParticleSwooshDataFactory::CreateGeneratorDescription(CInputStream& in, CSimplePool* resPool)
|
||||
{
|
||||
FourCC clsId = CPF::GetClassID(in);
|
||||
if (clsId == FOURCC('SWSH'))
|
||||
@@ -38,92 +38,92 @@ bool CParticleSwooshDataFactory::CreateWPSM(CSwooshDescription* desc, CInputStre
|
||||
while (clsId != SBIG('_END'))
|
||||
{
|
||||
CGlobalRandom gr(rand);
|
||||
switch(clsId)
|
||||
switch (clsId)
|
||||
{
|
||||
case SBIG('PSLT'):
|
||||
desc->x0_PSLT.reset(CPF::GetIntElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('TIME'):
|
||||
desc->x4_TIME.reset(CPF::GetRealElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('LRAD'):
|
||||
desc->x8_LRAD.reset(CPF::GetRealElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('RRAD'):
|
||||
desc->xc_RRAD.reset(CPF::GetRealElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('LENG'):
|
||||
desc->x10_LENG.reset(CPF::GetIntElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('COLR'):
|
||||
desc->x14_COLR.reset(CPF::GetColorElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('SIDE'):
|
||||
desc->x18_SIDE.reset(CPF::GetIntElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('IROT'):
|
||||
desc->x1c_IROT.reset(CPF::GetRealElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('ROTM'):
|
||||
desc->x20_ROTM.reset(CPF::GetRealElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('POFS'):
|
||||
desc->x24_POFS.reset(CPF::GetVectorElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('IVEL'):
|
||||
desc->x28_IVEL.reset(CPF::GetVectorElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('NPOS'):
|
||||
desc->x2c_NPOS.reset(CPF::GetVectorElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('VELM'):
|
||||
desc->x30_VELM.reset(CPF::GetModVectorElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('VLM2'):
|
||||
desc->x34_VLM2.reset(CPF::GetModVectorElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('SPLN'):
|
||||
desc->x38_SPLN.reset(CPF::GetIntElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('TEXR'):
|
||||
desc->x3c_TEXR.reset(CPF::GetTextureElement(in, resPool));
|
||||
break;
|
||||
break;
|
||||
case SBIG('TSPN'):
|
||||
desc->x40_TSPN.reset(CPF::GetIntElement(in));
|
||||
break;
|
||||
break;
|
||||
case SBIG('LLRD'):
|
||||
desc->x44_24_LLRD = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('CROS'):
|
||||
desc->x44_25_CROS = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('VLS1'):
|
||||
desc->x44_26_VLS1 = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('VLS2'):
|
||||
desc->x44_27_VLS2 = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('SROT'):
|
||||
desc->x44_28_SROT = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('WIRE'):
|
||||
desc->x44_29_WIRE = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('TEXW'):
|
||||
desc->x44_30_TEXW = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('AALP'):
|
||||
desc->x44_31_AALP = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('ZBUF'):
|
||||
desc->x45_24_ZBUF = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('ORNT'):
|
||||
desc->x45_25_ORNT = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
case SBIG('CRND'):
|
||||
desc->x45_26_CRND = CPF::GetBool(in);
|
||||
break;
|
||||
break;
|
||||
default:
|
||||
{
|
||||
uint32_t clsName = clsId.toUint32();
|
||||
@@ -137,10 +137,11 @@ bool CParticleSwooshDataFactory::CreateWPSM(CSwooshDescription* desc, CInputStre
|
||||
return true;
|
||||
}
|
||||
|
||||
CFactoryFnReturn FParticleSwooshDataFactory(const SObjectTag &tag, CInputStream &in, const CVParamTransfer &vparms)
|
||||
CFactoryFnReturn FParticleSwooshDataFactory(const SObjectTag& tag, CInputStream& in, const CVParamTransfer& vparms,
|
||||
CObjectReference*)
|
||||
{
|
||||
CSimplePool* sp = vparms.GetOwnedObj<CSimplePool*>();
|
||||
return TToken<CSwooshDescription>::GetIObjObjectFor(std::unique_ptr<CSwooshDescription>(CParticleSwooshDataFactory::GetGeneratorDesc(in, sp)));
|
||||
return TToken<CSwooshDescription>::GetIObjObjectFor(
|
||||
std::unique_ptr<CSwooshDescription>(CParticleSwooshDataFactory::GetGeneratorDesc(in, sp)));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user