2022-01-30 10:07:39 +00:00
|
|
|
/*
|
|
|
|
Copyright (C) 2015-2016, 2018-2020 cc9cii
|
|
|
|
|
|
|
|
This software is provided 'as-is', without any express or implied
|
|
|
|
warranty. In no event will the authors be held liable for any damages
|
|
|
|
arising from the use of this software.
|
|
|
|
|
|
|
|
Permission is granted to anyone to use this software for any purpose,
|
|
|
|
including commercial applications, and to alter it and redistribute it
|
|
|
|
freely, subject to the following restrictions:
|
|
|
|
|
|
|
|
1. The origin of this software must not be misrepresented; you must not
|
|
|
|
claim that you wrote the original software. If you use this software
|
|
|
|
in a product, an acknowledgment in the product documentation would be
|
|
|
|
appreciated but is not required.
|
|
|
|
2. Altered source versions must be plainly marked as such, and must not be
|
|
|
|
misrepresented as being the original software.
|
|
|
|
3. This notice may not be removed or altered from any source distribution.
|
|
|
|
|
|
|
|
cc9cii cc9c@iinet.net.au
|
|
|
|
|
|
|
|
Much of the information on the data structures are based on the information
|
|
|
|
from Tes4Mod:Mod_File_Format and Tes5Mod:File_Formats but also refined by
|
|
|
|
trial & error. See http://en.uesp.net/wiki for details.
|
|
|
|
|
|
|
|
*/
|
|
|
|
#ifndef ESM4_CELL_H
|
|
|
|
#define ESM4_CELL_H
|
|
|
|
|
|
|
|
#include <cstdint>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
2022-12-28 19:48:25 +00:00
|
|
|
#include <components/esm/defs.hpp>
|
|
|
|
#include <components/esm/refid.hpp>
|
2023-05-15 21:48:22 +00:00
|
|
|
#include <components/esm/util.hpp>
|
2023-03-04 22:40:41 +00:00
|
|
|
#include <components/esm4/reader.hpp>
|
2022-01-30 10:07:39 +00:00
|
|
|
|
2023-07-30 19:55:36 +00:00
|
|
|
#include "lighting.hpp"
|
|
|
|
|
2022-01-30 10:07:39 +00:00
|
|
|
namespace ESM4
|
|
|
|
{
|
|
|
|
class Reader;
|
|
|
|
class Writer;
|
|
|
|
struct ReaderContext;
|
|
|
|
struct CellGroup;
|
|
|
|
|
|
|
|
enum CellFlags // TES4 TES5
|
|
|
|
{ // ----------------------- ------------------------------------
|
|
|
|
CELL_Interior = 0x0001, // Can't travel from here Interior
|
|
|
|
CELL_HasWater = 0x0002, // Has water (Int) Has Water (Int)
|
|
|
|
CELL_NoTravel = 0x0004, // not Can't Travel From Here(Int only)
|
|
|
|
CELL_HideLand = 0x0008, // Force hide land (Ext) No LOD Water
|
|
|
|
// Oblivion interior (Int)
|
|
|
|
CELL_Public = 0x0020, // Public place Public Area
|
|
|
|
CELL_HandChgd = 0x0040, // Hand changed Hand Changed
|
|
|
|
CELL_QuasiExt = 0x0080, // Behave like exterior Show Sky
|
|
|
|
CELL_SkyLight = 0x0100 // Use Sky Lighting
|
|
|
|
};
|
|
|
|
|
|
|
|
// Unlike TES3, multiple cells can have the same exterior co-ordinates.
|
|
|
|
// The cells need to be organised under world spaces.
|
|
|
|
struct Cell
|
|
|
|
{
|
2023-07-30 19:55:36 +00:00
|
|
|
ESM::RefId mId; // from the header
|
2023-05-18 18:21:47 +00:00
|
|
|
std::uint32_t mFlags = 0; // from the header, see enum type RecordFlag for details
|
2022-01-30 10:07:39 +00:00
|
|
|
|
2023-02-20 21:33:35 +00:00
|
|
|
ESM::RefId mParent; // world formId (for grouping cells), from the loading sequence
|
2023-01-28 17:28:43 +00:00
|
|
|
|
2022-01-30 10:07:39 +00:00
|
|
|
std::string mEditorId;
|
|
|
|
std::string mFullName;
|
2023-05-18 18:21:47 +00:00
|
|
|
std::uint16_t mCellFlags = 0; // TES5 can also be 8 bits
|
2022-01-30 10:07:39 +00:00
|
|
|
|
2023-05-18 18:21:47 +00:00
|
|
|
std::int32_t mX = 0;
|
|
|
|
std::int32_t mY = 0;
|
2022-01-30 10:07:39 +00:00
|
|
|
|
2023-07-30 19:55:36 +00:00
|
|
|
ESM::FormId mOwner;
|
|
|
|
ESM::FormId mGlobal;
|
|
|
|
ESM::FormId mClimate;
|
|
|
|
ESM::FormId mWater;
|
2023-05-29 20:37:25 +00:00
|
|
|
float mWaterHeight = sInvalidWaterLevel;
|
2022-01-30 10:07:39 +00:00
|
|
|
|
2023-07-30 19:55:36 +00:00
|
|
|
std::vector<ESM::FormId> mRegions;
|
2022-01-30 10:07:39 +00:00
|
|
|
Lighting mLighting;
|
|
|
|
|
2023-07-30 19:55:36 +00:00
|
|
|
ESM::FormId mLightingTemplate; // FO3/FONV
|
2023-05-29 20:37:25 +00:00
|
|
|
std::uint32_t mLightingTemplateFlags = 0; // FO3/FONV
|
2022-01-30 10:07:39 +00:00
|
|
|
|
2023-07-30 19:55:36 +00:00
|
|
|
ESM::FormId mMusic; // FO3/FONV
|
|
|
|
ESM::FormId mAcousticSpace; // FO3/FONV
|
2022-01-30 10:07:39 +00:00
|
|
|
// TES4: 0 = default, 1 = public, 2 = dungeon
|
|
|
|
// FO3/FONV have more types (not sure how they are used, however)
|
2023-05-18 18:21:47 +00:00
|
|
|
std::uint8_t mMusicType = 0;
|
2022-01-30 10:07:39 +00:00
|
|
|
|
2023-05-18 18:21:47 +00:00
|
|
|
CellGroup* mCellGroup = nullptr;
|
2022-01-30 10:07:39 +00:00
|
|
|
|
2023-03-04 22:40:41 +00:00
|
|
|
ESM4::ReaderContext mReaderContext;
|
|
|
|
|
2022-04-24 17:20:17 +00:00
|
|
|
void load(ESM4::Reader& reader);
|
|
|
|
// void save(ESM4::Writer& writer) const;
|
2022-01-30 10:07:39 +00:00
|
|
|
|
|
|
|
void blank();
|
2022-12-28 19:48:25 +00:00
|
|
|
|
|
|
|
static constexpr ESM::RecNameInts sRecordId = ESM::REC_CELL4;
|
2023-01-22 22:40:55 +00:00
|
|
|
|
2023-01-27 00:13:17 +00:00
|
|
|
int getGridX() const { return mX; }
|
|
|
|
int getGridY() const { return mY; }
|
|
|
|
bool isExterior() const { return !(mCellFlags & CELL_Interior); }
|
2023-05-15 21:48:22 +00:00
|
|
|
ESM::ExteriorCellLocation getExteriorCellLocation() const
|
|
|
|
{
|
|
|
|
return ESM::ExteriorCellLocation(mX, mY, isExterior() ? mParent : mId);
|
|
|
|
}
|
2023-05-05 14:31:31 +00:00
|
|
|
static float sInvalidWaterLevel;
|
2022-01-30 10:07:39 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // ESM4_CELL_H
|