1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00
OpenMW/components/nif/extra.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

217 lines
5.2 KiB
C++
Raw Normal View History

#include "extra.hpp"
namespace Nif
{
2021-07-27 07:58:57 +03:00
void NiExtraData::read(NIFStream* nif)
{
Extra::read(nif);
2023-09-01 00:58:23 +03:00
nif->readVector(mData, mRecordSize);
}
void NiStringsExtraData::read(NIFStream* nif)
{
Extra::read(nif);
nif->getSizedStrings(mData, nif->get<uint32_t>());
}
void NiTextKeyExtraData::read(NIFStream* nif)
{
Extra::read(nif);
2022-09-22 21:26:05 +03:00
2023-09-01 00:58:23 +03:00
uint32_t numKeys;
nif->read(numKeys);
mList.resize(numKeys);
for (TextKey& key : mList)
2022-09-22 21:26:05 +03:00
{
2023-09-01 00:58:23 +03:00
nif->read(key.mTime);
nif->read(key.mText);
2022-09-22 21:26:05 +03:00
}
}
void NiVertWeightsExtraData::read(NIFStream* nif)
2022-09-22 21:26:05 +03:00
{
Extra::read(nif);
2023-09-01 00:58:23 +03:00
nif->skip(nif->get<uint16_t>() * sizeof(float)); // vertex weights I guess
}
2021-11-10 19:21:07 +03:00
void BSBound::read(NIFStream* nif)
2022-09-22 21:26:05 +03:00
{
2021-11-10 19:21:07 +03:00
Extra::read(nif);
2023-09-01 00:58:23 +03:00
nif->read(mCenter);
nif->read(mExtents);
2021-11-10 19:21:07 +03:00
}
void BSFurnitureMarker::LegacyFurniturePosition::read(NIFStream* nif)
{
2023-09-01 00:58:23 +03:00
nif->read(mOffset);
nif->read(mOrientation);
nif->read(mPositionRef);
nif->skip(1); // Position ref 2
2021-11-10 19:21:07 +03:00
}
void BSFurnitureMarker::FurniturePosition::read(NIFStream* nif)
{
2023-09-01 00:58:23 +03:00
nif->read(mOffset);
nif->read(mHeading);
nif->read(mType);
nif->read(mEntryPoint);
2021-11-10 19:21:07 +03:00
}
2022-09-22 21:26:05 +03:00
void BSFurnitureMarker::read(NIFStream* nif)
2021-11-10 19:21:07 +03:00
{
Extra::read(nif);
2023-09-01 00:58:23 +03:00
uint32_t num;
nif->read(num);
2021-11-10 19:21:07 +03:00
if (nif->getBethVersion() <= NIFFile::BethVersion::BETHVER_FO3)
2022-09-22 21:26:05 +03:00
{
mLegacyMarkers.resize(num);
for (auto& marker : mLegacyMarkers)
2021-11-10 19:21:07 +03:00
marker.read(nif);
2022-09-22 21:26:05 +03:00
}
else
{
mMarkers.resize(num);
for (auto& marker : mMarkers)
2021-11-10 19:21:07 +03:00
marker.read(nif);
2022-09-22 21:26:05 +03:00
}
2021-11-10 19:21:07 +03:00
}
2023-06-01 15:27:42 -05:00
void BSInvMarker::read(NIFStream* nif)
{
Extra::read(nif);
2023-09-01 00:58:23 +03:00
float rotX = nif->get<uint16_t>() / 1000.f;
float rotY = nif->get<uint16_t>() / 1000.f;
float rotZ = nif->get<uint16_t>() / 1000.f;
2023-06-01 15:27:42 -05:00
mRotation = osg::Quat(rotX, osg::X_AXIS, rotY, osg::Y_AXIS, rotZ, osg::Z_AXIS);
2023-09-01 00:58:23 +03:00
nif->read(mScale);
2023-06-01 15:27:42 -05:00
}
2023-07-20 03:38:15 +03:00
void BSBehaviorGraphExtraData::read(NIFStream* nif)
{
Extra::read(nif);
2023-09-01 00:58:23 +03:00
nif->read(mFile);
nif->read(mControlsBaseSkeleton);
2023-07-20 03:38:15 +03:00
}
void BSBoneLODExtraData::read(NIFStream* nif)
{
Extra::read(nif);
mData.resize(nif->get<uint32_t>());
for (BoneLOD& lod : mData)
lod.read(nif);
}
void BSBoneLODExtraData::BoneLOD::read(NIFStream* nif)
{
nif->read(mDistance);
nif->read(mBone);
}
void BSDecalPlacementVectorExtraData::read(NIFStream* nif)
{
NiFloatExtraData::read(nif);
mBlocks.resize(nif->get<uint16_t>());
for (Block& block : mBlocks)
block.read(nif);
}
void BSDecalPlacementVectorExtraData::Block::read(NIFStream* nif)
{
nif->readVector(mPoints, nif->get<uint16_t>());
nif->readVector(mNormals, mPoints.size());
}
void BSClothExtraData::read(NIFStream* nif)
{
nif->readVector(mData, nif->get<uint32_t>());
2023-11-08 12:33:26 +03:00
}
void BSCollisionQueryProxyExtraData::read(NIFStream* nif)
{
nif->readVector(mData, nif->get<uint32_t>());
}
2023-09-27 12:54:38 +03:00
void BSConnectPoint::Point::read(NIFStream* nif)
{
mParent = nif->getSizedString();
mName = nif->getSizedString();
nif->read(mTransform.mRotation);
nif->read(mTransform.mTranslation);
nif->read(mTransform.mScale);
}
void BSConnectPoint::Parents::read(NIFStream* nif)
{
NiExtraData::read(nif);
mPoints.resize(nif->get<uint32_t>());
for (Point& point : mPoints)
point.read(nif);
}
void BSConnectPoint::Children::read(NIFStream* nif)
{
NiExtraData::read(nif);
nif->read(mSkinned);
nif->getSizedStrings(mPointNames, nif->get<uint32_t>());
}
void BSPackedGeomDataCombined::read(NIFStream* nif)
{
nif->read(mGrayscaleToPaletteScale);
nif->read(mTransform);
nif->read(mBoundingSphere);
}
void BSPackedGeomObject::read(NIFStream* nif)
{
nif->read(mFileHash);
nif->read(mDataOffset);
}
void BSPackedSharedGeomData::read(NIFStream* nif)
{
nif->read(mNumVertices);
nif->read(mLODLevels);
nif->read(mLOD0TriCount);
nif->read(mLOD0TriOffset);
nif->read(mLOD1TriCount);
nif->read(mLOD1TriOffset);
nif->read(mLOD2TriCount);
nif->read(mLOD2TriOffset);
mCombined.resize(nif->get<uint32_t>());
for (BSPackedGeomDataCombined& data : mCombined)
data.read(nif);
mVertexDesc.read(nif);
}
void BSPackedCombinedSharedGeomDataExtra::read(NIFStream* nif)
{
NiExtraData::read(nif);
mVertexDesc.read(nif);
nif->read(mNumVertices);
nif->read(mNumTriangles);
nif->read(mFlags1);
nif->read(mFlags2);
mObjects.resize(nif->get<uint32_t>());
for (BSPackedGeomObject& object : mObjects)
object.read(nif);
mObjectData.resize(mObjects.size());
for (BSPackedSharedGeomData& objectData : mObjectData)
objectData.read(nif);
}
}