Read even more Gamebryo/Bethesda particle records

macos_ci_fix
Alexei Kotov 1 year ago
parent 8594875ccb
commit 120223d8df

@ -295,7 +295,10 @@ namespace Nif
// Modifiers, Gamebryo // Modifiers, Gamebryo
{ "NiPSysAgeDeathModifier", &construct<NiPSysAgeDeathModifier, RC_NiPSysAgeDeathModifier> }, { "NiPSysAgeDeathModifier", &construct<NiPSysAgeDeathModifier, RC_NiPSysAgeDeathModifier> },
{ "NiPSysBoundUpdateModifier", &construct<NiPSysBoundUpdateModifier, RC_NiPSysBoundUpdateModifier> }, { "NiPSysBoundUpdateModifier", &construct<NiPSysBoundUpdateModifier, RC_NiPSysBoundUpdateModifier> },
{ "NiPSysDragModifier", &construct<NiPSysDragModifier, RC_NiPSysDragModifier> },
{ "NiPSysGravityModifier", &construct<NiPSysGravityModifier, RC_NiPSysGravityModifier> },
{ "NiPSysPositionModifier", &construct<NiPSysModifier, RC_NiPSysPositionModifier> }, { "NiPSysPositionModifier", &construct<NiPSysModifier, RC_NiPSysPositionModifier> },
{ "NiPSysRotationModifier", &construct<NiPSysRotationModifier, RC_NiPSysRotationModifier> },
{ "NiPSysSpawnModifier", &construct<NiPSysSpawnModifier, RC_NiPSysSpawnModifier> }, { "NiPSysSpawnModifier", &construct<NiPSysSpawnModifier, RC_NiPSysSpawnModifier> },
// Modifiers, Bethesda // Modifiers, Bethesda
@ -308,6 +311,7 @@ namespace Nif
// Emitters // Emitters
{ "NiPSysBoxEmitter", &construct<NiPSysBoxEmitter, RC_NiPSysBoxEmitter> }, { "NiPSysBoxEmitter", &construct<NiPSysBoxEmitter, RC_NiPSysBoxEmitter> },
{ "NiPSysCylinderEmitter", &construct<NiPSysCylinderEmitter, RC_NiPSysCylinderEmitter> }, { "NiPSysCylinderEmitter", &construct<NiPSysCylinderEmitter, RC_NiPSysCylinderEmitter> },
{ "NiPSysMeshEmitter", &construct<NiPSysMeshEmitter, RC_NiPSysMeshEmitter> },
{ "NiPSysSphereEmitter", &construct<NiPSysSphereEmitter, RC_NiPSysSphereEmitter> }, { "NiPSysSphereEmitter", &construct<NiPSysSphereEmitter, RC_NiPSysSphereEmitter> },
// Modifier controllers, Gamebryo // Modifier controllers, Gamebryo

@ -260,6 +260,69 @@ namespace Nif
nif->read(mUpdateSkip); nif->read(mUpdateSkip);
} }
void NiPSysDragModifier::read(NIFStream* nif)
{
NiPSysModifier::read(nif);
mDragObject.read(nif);
nif->read(mDragAxis);
nif->read(mPercentage);
nif->read(mRange);
nif->read(mRangeFalloff);
}
void NiPSysDragModifier::post(Reader& nif)
{
NiPSysModifier::post(nif);
mDragObject.post(nif);
}
void NiPSysGravityModifier::read(NIFStream* nif)
{
NiPSysModifier::read(nif);
mGravityObject.read(nif);
nif->read(mGravityAxis);
nif->read(mDecay);
nif->read(mStrength);
mForceType = static_cast<ForceType>(nif->get<uint32_t>());
nif->read(mTurbulence);
nif->read(mTurbulenceScale);
if (nif->getBethVersion() >= 17)
nif->read(mWorldAligned);
}
void NiPSysGravityModifier::post(Reader& nif)
{
NiPSysModifier::post(nif);
mGravityObject.post(nif);
}
void NiPSysRotationModifier::read(NIFStream* nif)
{
NiPSysModifier::read(nif);
nif->read(mRotationSpeed);
if (nif->getVersion() >= NIFStream::generateVersion(20, 0, 0, 2))
{
nif->read(mRotationSpeedVariation);
if (nif->getBethVersion() >= NIFFile::BethVersion::BETHVER_F76)
nif->skip(5); // Unknown
nif->read(mRotationAngle);
nif->read(mRotationAngleVariation);
nif->read(mRandomRotSpeedSign);
}
nif->read(mRandomAxis);
nif->read(mAxis);
}
void NiPSysSpawnModifier::read(NIFStream* nif) void NiPSysSpawnModifier::read(NIFStream* nif)
{ {
NiPSysModifier::read(nif); NiPSysModifier::read(nif);
@ -373,6 +436,24 @@ namespace Nif
nif->read(mHeight); nif->read(mHeight);
} }
void NiPSysMeshEmitter::read(NIFStream* nif)
{
NiPSysEmitter::read(nif);
readRecordList(nif, mEmitterMeshes);
nif->read(mInitialVelocityType);
nif->read(mEmissionType);
nif->read(mEmissionAxis);
}
void NiPSysMeshEmitter::post(Reader& nif)
{
NiPSysEmitter::post(nif);
postRecordList(nif, mEmitterMeshes);
}
void NiPSysSphereEmitter::read(NIFStream* nif) void NiPSysSphereEmitter::read(NIFStream* nif)
{ {
NiPSysVolumeEmitter::read(nif); NiPSysVolumeEmitter::read(nif);

@ -34,14 +34,14 @@ namespace Nif
void post(Reader& nif) override; void post(Reader& nif) override;
}; };
struct NiGravity : public NiParticleModifier
{
enum class ForceType : uint32_t enum class ForceType : uint32_t
{ {
Wind = 0, // Fixed direction Wind = 0, // Fixed direction
Point = 1, // Fixed origin Point = 1, // Fixed origin
}; };
struct NiGravity : public NiParticleModifier
{
float mDecay{ 0.f }; float mDecay{ 0.f };
float mForce; float mForce;
ForceType mType; ForceType mType;
@ -193,6 +193,46 @@ namespace Nif
void read(NIFStream* nif) override; void read(NIFStream* nif) override;
}; };
struct NiPSysDragModifier : public NiPSysModifier
{
NiAVObjectPtr mDragObject;
osg::Vec3f mDragAxis;
float mPercentage;
float mRange;
float mRangeFalloff;
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
struct NiPSysGravityModifier : public NiPSysModifier
{
NiAVObjectPtr mGravityObject;
osg::Vec3f mGravityAxis;
float mDecay;
float mStrength;
ForceType mForceType;
float mTurbulence;
float mTurbulenceScale;
bool mWorldAligned;
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
struct NiPSysRotationModifier : public NiPSysModifier
{
float mRotationSpeed;
float mRotationSpeedVariation;
float mRotationAngle;
float mRotationAngleVariation;
bool mRandomRotSpeedSign;
bool mRandomAxis;
osg::Vec3f mAxis;
void read(NIFStream* nif) override;
};
struct NiPSysSpawnModifier : NiPSysModifier struct NiPSysSpawnModifier : NiPSysModifier
{ {
uint16_t mNumSpawnGenerations; uint16_t mNumSpawnGenerations;
@ -209,7 +249,7 @@ namespace Nif
struct BSPSysInheritVelocityModifier : public NiPSysModifier struct BSPSysInheritVelocityModifier : public NiPSysModifier
{ {
NiObjectNETPtr mInheritObject; NiAVObjectPtr mInheritObject;
float mInheritChance; float mInheritChance;
float mVelocityMult; float mVelocityMult;
float mVelcoityVariation; float mVelcoityVariation;
@ -292,6 +332,17 @@ namespace Nif
void read(NIFStream* nif) override; void read(NIFStream* nif) override;
}; };
struct NiPSysMeshEmitter : public NiPSysEmitter
{
NiAVObjectList mEmitterMeshes;
uint32_t mInitialVelocityType;
uint32_t mEmissionType;
osg::Vec3f mEmissionAxis;
void read(NIFStream* nif) override;
void post(Reader& nif) override;
};
struct NiPSysSphereEmitter : public NiPSysVolumeEmitter struct NiPSysSphereEmitter : public NiPSysVolumeEmitter
{ {
float mRadius; float mRadius;

@ -194,6 +194,7 @@ namespace Nif
RC_NiPSysBoundUpdateModifier, RC_NiPSysBoundUpdateModifier,
RC_NiPSysCylinderEmitter, RC_NiPSysCylinderEmitter,
RC_NiPSysData, RC_NiPSysData,
RC_NiPSysDragModifier,
RC_NiPSysEmitterCtlr, RC_NiPSysEmitterCtlr,
RC_NiPSysEmitterCtlrData, RC_NiPSysEmitterCtlrData,
RC_NiPSysEmitterDeclinationCtlr, RC_NiPSysEmitterDeclinationCtlr,
@ -206,13 +207,16 @@ namespace Nif
RC_NiPSysFieldAttenuationCtlr, RC_NiPSysFieldAttenuationCtlr,
RC_NiPSysFieldMagnitudeCtlr, RC_NiPSysFieldMagnitudeCtlr,
RC_NiPSysFieldMaxDistanceCtlr, RC_NiPSysFieldMaxDistanceCtlr,
RC_NiPSysGravityModifier,
RC_NiPSysGravityStrengthCtlr, RC_NiPSysGravityStrengthCtlr,
RC_NiPSysInitialRotSpeedCtlr, RC_NiPSysInitialRotSpeedCtlr,
RC_NiPSysInitialRotSpeedVarCtlr, RC_NiPSysInitialRotSpeedVarCtlr,
RC_NiPSysInitialRotAngleCtlr, RC_NiPSysInitialRotAngleCtlr,
RC_NiPSysInitialRotAngleVarCtlr, RC_NiPSysInitialRotAngleVarCtlr,
RC_NiPSysMeshEmitter,
RC_NiPSysModifierActiveCtlr, RC_NiPSysModifierActiveCtlr,
RC_NiPSysPositionModifier, RC_NiPSysPositionModifier,
RC_NiPSysRotationModifier,
RC_NiPSysResetOnLoopCtlr, RC_NiPSysResetOnLoopCtlr,
RC_NiPSysSpawnModifier, RC_NiPSysSpawnModifier,
RC_NiPSysSphereEmitter, RC_NiPSysSphereEmitter,

@ -304,7 +304,7 @@ namespace NifOsg
bool absolute = (program->getReferenceFrame() == osgParticle::ParticleProcessor::ABSOLUTE_RF); bool absolute = (program->getReferenceFrame() == osgParticle::ParticleProcessor::ABSOLUTE_RF);
// We don't need the position for Wind gravity, except if decay is being applied // We don't need the position for Wind gravity, except if decay is being applied
if (mType == Nif::NiGravity::ForceType::Point || mDecay != 0.f) if (mType == Nif::ForceType::Point || mDecay != 0.f)
mCachedWorldPosition = absolute ? program->transformLocalToWorld(mPosition) : mPosition; mCachedWorldPosition = absolute ? program->transformLocalToWorld(mPosition) : mPosition;
mCachedWorldDirection = absolute ? program->rotateLocalToWorld(mDirection) : mDirection; mCachedWorldDirection = absolute ? program->rotateLocalToWorld(mDirection) : mDirection;
@ -316,7 +316,7 @@ namespace NifOsg
const float magic = 1.6f; const float magic = 1.6f;
switch (mType) switch (mType)
{ {
case Nif::NiGravity::ForceType::Wind: case Nif::ForceType::Wind:
{ {
float decayFactor = 1.f; float decayFactor = 1.f;
if (mDecay != 0.f) if (mDecay != 0.f)
@ -330,7 +330,7 @@ namespace NifOsg
break; break;
} }
case Nif::NiGravity::ForceType::Point: case Nif::ForceType::Point:
{ {
osg::Vec3f diff = mCachedWorldPosition - particle->getPosition(); osg::Vec3f diff = mCachedWorldPosition - particle->getPosition();

@ -191,7 +191,7 @@ namespace NifOsg
private: private:
float mForce{ 0.f }; float mForce{ 0.f };
Nif::NiGravity::ForceType mType{ Nif::NiGravity::ForceType::Wind }; Nif::ForceType mType{ Nif::ForceType::Wind };
osg::Vec3f mPosition; osg::Vec3f mPosition;
osg::Vec3f mDirection; osg::Vec3f mDirection;
float mDecay{ 0.f }; float mDecay{ 0.f };

Loading…
Cancel
Save