2023-05-14 21:42:15 +00:00
|
|
|
#ifndef COMPONENTS_ESM_ESMTERRAIN
|
|
|
|
#define COMPONENTS_ESM_ESMTERRAIN
|
|
|
|
|
|
|
|
#include <span>
|
2023-05-26 00:14:56 +00:00
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <components/esm3/loadland.hpp>
|
|
|
|
#include <components/esm4/loadland.hpp>
|
2023-05-14 21:42:15 +00:00
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
class LandData
|
|
|
|
{
|
|
|
|
|
|
|
|
public:
|
2023-05-26 00:14:56 +00:00
|
|
|
~LandData() = default;
|
|
|
|
LandData() = default;
|
|
|
|
LandData(const ESM::Land& Land, int loadFLags);
|
|
|
|
LandData(const ESM4::Land& Land, int loadFLags);
|
2023-05-14 22:34:17 +00:00
|
|
|
|
2023-05-14 21:42:15 +00:00
|
|
|
typedef signed char VNML;
|
|
|
|
|
2023-05-26 00:14:56 +00:00
|
|
|
std::span<const float> getHeights() const { return mHeights; }
|
|
|
|
std::span<const VNML> getNormals() const { return mNormals; }
|
|
|
|
std::span<const unsigned char> getColors() const { return mColors; }
|
|
|
|
std::span<const uint16_t> getTextures() const { return mTextures; }
|
|
|
|
float getSize() const { return mSize; }
|
|
|
|
float getMinHeight() const { return mMinHeight; }
|
|
|
|
float getMaxHeight() const { return mMaxHeight; }
|
|
|
|
int getLandSize() const { return mLandSize; }
|
|
|
|
|
|
|
|
int mLoadFlags;
|
|
|
|
|
|
|
|
private:
|
|
|
|
float mMinHeight = 0.f;
|
|
|
|
float mMaxHeight = 0.f;
|
|
|
|
float mSize = 0.f;
|
|
|
|
int mLandSize = 0;
|
|
|
|
std::vector<float> mHeights;
|
|
|
|
std::vector<VNML> mNormals;
|
|
|
|
std::vector<unsigned char> mColors;
|
|
|
|
std::vector<uint16_t> mTextures;
|
2023-05-14 21:42:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif // ! COMPNENTS_ESM_ESMTERRAIN
|