#pragma once #include "dZMCommon.h" #include <map> #include <iostream> #include "Zone.h" class Level { public: enum ChunkTypeID : uint16_t { FileInfo = 1000, SceneEnviroment = 2000, SceneObjectData, SceneParticleData }; enum ChunkTypes { Enviroment, Objects, Particles }; struct FileInfoChunk { uint32_t version; uint32_t revision; uint32_t enviromentChunkStart; uint32_t objectChunkStart; uint32_t particleChunkStart; }; struct SceneObjectDataChunk { std::map<LWOOBJID, SceneObject> objects; SceneObject& GetObject(LWOOBJID id) { for (std::map<LWOOBJID, SceneObject>::iterator it = objects.begin(); it != objects.end(); ++it) { if (it->first == id) return it->second; } } const void PrintAllObjects() { for (std::map<LWOOBJID, SceneObject>::iterator it = objects.begin(); it != objects.end(); ++it) { std::cout << "\t ID: " << it->first << " LOT: " << it->second.lot << std::endl; } } uint32_t GetObjectCount() { return objects.size(); } }; struct Header { uint32_t id; uint16_t chunkVersion; ChunkTypeID chunkType; uint32_t size; uint32_t startPosition; FileInfoChunk* fileInfo; SceneObjectDataChunk* sceneObjects; LWOSCENEID lwoSceneID; }; public: Level(Zone* parentZone, const std::string& filepath); ~Level(); const void PrintAllObjects(); std::map<uint32_t, Header> m_ChunkHeaders; private: Zone* m_ParentZone; //private functions: void ReadChunks(std::ifstream& file); void ReadFileInfoChunk(std::ifstream& file, Header& header); void ReadSceneObjectDataChunk(std::ifstream& file, Header& header); };