metaforce/DataSpec/DNAMP3/MREA.hpp

130 lines
3.4 KiB
C++
Raw Normal View History

2015-09-20 06:09:27 +00:00
#ifndef __DNAMP3_MREA_HPP__
#define __DNAMP3_MREA_HPP__
#include "../DNACommon/DNACommon.hpp"
#include "CMDLMaterials.hpp"
#include "CSKR.hpp"
#include "../DNAMP2/MREA.hpp"
namespace Retro
{
namespace DNAMP3
{
struct MREA
{
2015-09-23 06:35:07 +00:00
struct StreamReader : DNAMP2::MREA::StreamReader
2015-09-20 06:09:27 +00:00
{
std::vector<std::pair<DNAFourCC, atUint32>> m_secIdxs;
StreamReader(Athena::io::IStreamReader& source,
atUint32 blkCount, atUint32 secIdxCount);
std::vector<std::pair<DNAFourCC, atUint32>>::const_iterator beginSecIdxs()
{
return m_secIdxs.begin();
}
void writeSecIdxs(Athena::io::IStreamWriter& writer) const;
};
struct Header : BigDNA
{
DECL_DNA
Value<atUint32> magic;
Value<atUint32> version;
Value<atVec4f> localToWorldMtx[3];
Value<atUint32> meshCount;
Value<atUint32> sclyLayerCount;
Value<atUint32> secCount;
Value<atUint32> compressedBlockCount;
Value<atUint32> secIndexCount;
Seek<20, Athena::Current> align1;
Vector<atUint32, DNA_COUNT(secCount)> secSizes;
2015-09-23 06:35:07 +00:00
atUint32 getSecOffset(atUint32 idx) const
{
if (idx >= secSizes.size())
return -1;
atUint32 retval = 0;
for (atUint32 i=0 ; i<idx ; ++i)
retval += secSizes[i];
return retval;
}
2015-09-20 06:09:27 +00:00
};
struct MeshHeader : BigDNA
{
DECL_DNA
struct VisorFlags : BigDNA
{
DECL_DNA
Value<atUint32> flags;
} visorFlags;
Value<atVec4f> xfMtx[3];
Value<atVec3f> aabb[2];
};
2015-09-23 06:35:07 +00:00
struct DEPS : BigDNA
{
DECL_DNA
Value<atUint32> depCount;
struct Dependency : BigDNA
{
DECL_DNA
UniqueID64 id;
DNAFourCC type;
};
Vector<Dependency, DNA_COUNT(depCount)> deps;
Value<atUint32> depLayerCount;
Vector<atUint32, DNA_COUNT(depLayerCount)> depLayers;
};
2015-09-20 06:09:27 +00:00
struct BabeDeadLight : BigDNA
{
DECL_DNA
enum LightType : atUint32
{
LightLocalAmbient,
LightDirectional,
LightCustom,
LightSpot
};
2015-09-28 05:19:31 +00:00
enum Falloff : atUint32
{
FalloffConstant,
FalloffLinear,
FalloffQuadratic
};
2015-09-20 06:09:27 +00:00
Value<LightType> lightType;
Value<atVec4f> color;
Value<atVec3f> position;
2015-09-23 01:15:11 +00:00
Value<atVec3f> direction;
Value<atVec3f> codirection;
2015-09-28 05:19:31 +00:00
Value<float> q;
Value<float> spotCutoff;
2015-09-23 01:15:11 +00:00
Value<float> unk7;
Value<atUint8> unk8;
2015-09-28 05:19:31 +00:00
Value<float> unk9;
Value<Falloff> falloff;
2015-09-26 03:12:08 +00:00
Value<float> unk11;
2015-09-20 06:09:27 +00:00
Value<atVec4f> unk12;
Value<atUint32> unk13;
};
static void ReadBabeDeadToBlender_3(HECL::BlenderConnection::PyOutStream& os,
Athena::io::IStreamReader& rs);
static bool Extract(const SpecBase& dataSpec,
PAKEntryReadStream& rs,
const HECL::ProjectPath& outPath,
PAKRouter<PAKBridge>& pakRouter,
const PAK::Entry& entry,
bool,
std::function<void(const HECL::SystemChar*)>);
2015-09-23 06:35:07 +00:00
static bool ExtractLayerDeps(PAKEntryReadStream& rs, PAKBridge::Level::Area& areaOut);
2015-09-20 06:09:27 +00:00
};
}
}
#endif // __DNAMP3_MREA_HPP__