/* OpenMW - The completely unofficial reimplementation of Morrowind Copyright (C) 2008-2010 Nicolay Korslund Email: < korslund@gmail.com > WWW: https://openmw.org/ This file (data.h) is part of the OpenMW package. OpenMW is distributed as free software: you can redistribute it and/or modify it under the terms of the GNU General Public License version 3, as published by the Free Software Foundation. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License version 3 along with this program. If not, see https://www.gnu.org/licenses/ . */ #ifndef OPENMW_COMPONENTS_NIF_DATA_HPP #define OPENMW_COMPONENTS_NIF_DATA_HPP #include "base.hpp" #include "niftypes.hpp" // Transformation namespace Nif { // Common ancestor for several data classes class NiGeometryData : public Record { public: std::vector vertices, normals, tangents, bitangents; std::vector colors; std::vector< std::vector > uvlist; osg::Vec3f center; float radius; void read(NIFStream *nif) override; }; class NiTriShapeData : public NiGeometryData { public: // Triangles, three vertex indices per triangle std::vector triangles; void read(NIFStream *nif) override; }; class NiTriStripsData : public NiGeometryData { public: // Triangle strips, series of vertex indices. std::vector> strips; void read(NIFStream *nif) override; }; struct NiLinesData : public NiGeometryData { // Lines, series of indices that correspond to connected vertices. std::vector lines; void read(NIFStream *nif) override; }; class NiAutoNormalParticlesData : public NiGeometryData { public: int numParticles{0}; int activeCount; std::vector particleRadii, sizes, rotationAngles; std::vector rotations; std::vector rotationAxes; void read(NIFStream *nif) override; }; class NiRotatingParticlesData : public NiAutoNormalParticlesData { public: void read(NIFStream *nif) override; }; class NiPosData : public Record { public: Vector3KeyMapPtr mKeyList; void read(NIFStream *nif) override; }; class NiUVData : public Record { public: FloatKeyMapPtr mKeyList[4]; void read(NIFStream *nif) override; }; class NiFloatData : public Record { public: FloatKeyMapPtr mKeyList; void read(NIFStream *nif) override; }; class NiPixelData : public Record { public: enum Format { NIPXFMT_RGB8, NIPXFMT_RGBA8, NIPXFMT_PAL8, NIPXFMT_PALA8, NIPXFMT_DXT1, NIPXFMT_DXT3, NIPXFMT_DXT5, NIPXFMT_DXT5_ALT }; Format fmt; unsigned int colorMask[4]; unsigned int bpp, pixelTiling{0}; bool sRGB{false}; NiPalettePtr palette; unsigned int numberOfMipmaps; struct Mipmap { int width, height; int dataOffset; }; std::vector mipmaps; std::vector data; void read(NIFStream *nif) override; void post(NIFFile *nif) override; }; class NiColorData : public Record { public: Vector4KeyMapPtr mKeyMap; void read(NIFStream *nif) override; }; class NiVisData : public Record { public: struct VisData { float time; bool isSet; }; std::vector mVis; void read(NIFStream *nif) override; }; class NiSkinInstance : public Record { public: NiSkinDataPtr data; NodePtr root; NodeList bones; void read(NIFStream *nif) override; void post(NIFFile *nif) override; }; class NiSkinData : public Record { public: struct VertWeight { unsigned short vertex; float weight; }; struct BoneInfo { Transformation trafo; osg::Vec3f boundSphereCenter; float boundSphereRadius; std::vector weights; }; Transformation trafo; std::vector bones; void read(NIFStream *nif) override; }; struct NiMorphData : public Record { struct MorphData { FloatKeyMapPtr mKeyFrames; std::vector mVertices; }; std::vector mMorphs; void read(NIFStream *nif) override; }; struct NiKeyframeData : public Record { QuaternionKeyMapPtr mRotations; // may be NULL FloatKeyMapPtr mXRotations; FloatKeyMapPtr mYRotations; FloatKeyMapPtr mZRotations; Vector3KeyMapPtr mTranslations; FloatKeyMapPtr mScales; void read(NIFStream *nif) override; }; class NiPalette : public Record { public: // 32-bit RGBA colors that correspond to 8-bit indices std::vector colors; void read(NIFStream *nif) override; }; } // Namespace #endif