mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 19:56:37 +00:00
Accept boolean-based and 4D vector-based NiInterpolators in ValueInterpolator constructor
339 lines
8.5 KiB
C++
339 lines
8.5 KiB
C++
#include "controller.hpp"
|
|
|
|
#include "node.hpp"
|
|
#include "data.hpp"
|
|
|
|
namespace Nif
|
|
{
|
|
|
|
void Controller::read(NIFStream *nif)
|
|
{
|
|
next.read(nif);
|
|
|
|
flags = nif->getUShort();
|
|
|
|
frequency = nif->getFloat();
|
|
phase = nif->getFloat();
|
|
timeStart = nif->getFloat();
|
|
timeStop = nif->getFloat();
|
|
|
|
target.read(nif);
|
|
}
|
|
|
|
void Controller::post(NIFFile *nif)
|
|
{
|
|
Record::post(nif);
|
|
next.post(nif);
|
|
target.post(nif);
|
|
}
|
|
|
|
void NiParticleSystemController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
|
|
velocity = nif->getFloat();
|
|
velocityRandom = nif->getFloat();
|
|
verticalDir = nif->getFloat();
|
|
verticalAngle = nif->getFloat();
|
|
horizontalDir = nif->getFloat();
|
|
horizontalAngle = nif->getFloat();
|
|
/*normal?*/ nif->getVector3();
|
|
/*color?*/ nif->getVector4();
|
|
size = nif->getFloat();
|
|
startTime = nif->getFloat();
|
|
stopTime = nif->getFloat();
|
|
nif->getChar();
|
|
emitRate = nif->getFloat();
|
|
lifetime = nif->getFloat();
|
|
lifetimeRandom = nif->getFloat();
|
|
|
|
emitFlags = nif->getUShort();
|
|
offsetRandom = nif->getVector3();
|
|
|
|
emitter.read(nif);
|
|
|
|
/* Unknown Short, 0?
|
|
* Unknown Float, 1.0?
|
|
* Unknown Int, 1?
|
|
* Unknown Int, 0?
|
|
* Unknown Short, 0?
|
|
*/
|
|
nif->skip(16);
|
|
|
|
numParticles = nif->getUShort();
|
|
activeCount = nif->getUShort();
|
|
|
|
particles.resize(numParticles);
|
|
for(size_t i = 0;i < particles.size();i++)
|
|
{
|
|
particles[i].velocity = nif->getVector3();
|
|
nif->getVector3(); /* unknown */
|
|
particles[i].lifetime = nif->getFloat();
|
|
particles[i].lifespan = nif->getFloat();
|
|
particles[i].timestamp = nif->getFloat();
|
|
nif->getUShort(); /* unknown */
|
|
particles[i].vertex = nif->getUShort();
|
|
}
|
|
|
|
nif->getUInt(); /* -1? */
|
|
affectors.read(nif);
|
|
colliders.read(nif);
|
|
nif->getChar();
|
|
}
|
|
|
|
void NiParticleSystemController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
emitter.post(nif);
|
|
affectors.post(nif);
|
|
colliders.post(nif);
|
|
}
|
|
|
|
void NiMaterialColorController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
if (nif->getVersion() > NIFStream::generateVersion(10,1,0,103))
|
|
interpolator.read(nif);
|
|
// Two bits that correspond to the controlled material color.
|
|
// 00: Ambient
|
|
// 01: Diffuse
|
|
// 10: Specular
|
|
// 11: Emissive
|
|
if (nif->getVersion() >= NIFStream::generateVersion(10,1,0,0))
|
|
targetColor = nif->getUShort() & 3;
|
|
else
|
|
targetColor = (flags >> 4) & 3;
|
|
if (nif->getVersion() <= NIFStream::generateVersion(10,1,0,103))
|
|
data.read(nif);
|
|
}
|
|
|
|
void NiMaterialColorController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
interpolator.post(nif);
|
|
data.post(nif);
|
|
}
|
|
|
|
void NiLookAtController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
if (nif->getVersion() >= NIFStream::generateVersion(10,1,0,0))
|
|
lookAtFlags = nif->getUShort();
|
|
target.read(nif);
|
|
}
|
|
|
|
void NiLookAtController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
target.post(nif);
|
|
}
|
|
|
|
void NiPathController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
|
|
bankDir = nif->getInt();
|
|
maxBankAngle = nif->getFloat();
|
|
smoothing = nif->getFloat();
|
|
followAxis = nif->getShort();
|
|
posData.read(nif);
|
|
floatData.read(nif);
|
|
}
|
|
|
|
void NiPathController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
|
|
posData.post(nif);
|
|
floatData.post(nif);
|
|
}
|
|
|
|
void NiUVController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
|
|
uvSet = nif->getUShort();
|
|
data.read(nif);
|
|
}
|
|
|
|
void NiUVController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
data.post(nif);
|
|
}
|
|
|
|
void NiKeyframeController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
if (nif->getVersion() <= NIFStream::generateVersion(10,1,0,103))
|
|
data.read(nif);
|
|
else
|
|
interpolator.read(nif);
|
|
}
|
|
|
|
void NiKeyframeController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
data.post(nif);
|
|
interpolator.post(nif);
|
|
}
|
|
|
|
void NiFloatInterpController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
if (nif->getVersion() <= NIFStream::generateVersion(10,1,0,103))
|
|
data.read(nif);
|
|
else
|
|
interpolator.read(nif);
|
|
}
|
|
|
|
void NiFloatInterpController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
data.post(nif);
|
|
interpolator.post(nif);
|
|
}
|
|
|
|
void NiGeomMorpherController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
if (nif->getVersion() >= NIFFile::NIFVersion::VER_OB_OLD)
|
|
/*bool updateNormals = !!*/nif->getUShort();
|
|
data.read(nif);
|
|
if (nif->getVersion() >= NIFFile::NIFVersion::VER_MW)
|
|
{
|
|
/*bool alwaysActive = */nif->getChar(); // Always 0
|
|
if (nif->getVersion() >= NIFStream::generateVersion(10,1,0,106))
|
|
{
|
|
if (nif->getVersion() <= NIFFile::NIFVersion::VER_OB)
|
|
{
|
|
interpolators.read(nif);
|
|
if (nif->getVersion() >= NIFStream::generateVersion(10,2,0,0) && nif->getBethVersion() > 9)
|
|
{
|
|
unsigned int numUnknown = nif->getUInt();
|
|
nif->skip(4 * numUnknown);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// TODO: handle weighted interpolators
|
|
unsigned int numInterps = nif->getUInt();
|
|
nif->skip(8 * numInterps);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
void NiGeomMorpherController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
data.post(nif);
|
|
interpolators.post(nif);
|
|
}
|
|
|
|
void NiVisController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
data.read(nif);
|
|
}
|
|
|
|
void NiVisController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
data.post(nif);
|
|
}
|
|
|
|
void NiFlipController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
if (nif->getVersion() >= NIFStream::generateVersion(10,2,0,0))
|
|
mInterpolator.read(nif);
|
|
mTexSlot = nif->getUInt();
|
|
if (nif->getVersion() <= NIFStream::generateVersion(10,1,0,103))
|
|
{
|
|
timeStart = nif->getFloat();
|
|
mDelta = nif->getFloat();
|
|
}
|
|
mSources.read(nif);
|
|
}
|
|
|
|
void NiFlipController::post(NIFFile *nif)
|
|
{
|
|
Controller::post(nif);
|
|
mInterpolator.post(nif);
|
|
mSources.post(nif);
|
|
}
|
|
|
|
void bhkBlendController::read(NIFStream *nif)
|
|
{
|
|
Controller::read(nif);
|
|
nif->getUInt(); // Zero
|
|
}
|
|
|
|
void NiPoint3Interpolator::read(NIFStream *nif)
|
|
{
|
|
defaultVal = nif->getVector3();
|
|
data.read(nif);
|
|
}
|
|
|
|
void NiPoint3Interpolator::post(NIFFile *nif)
|
|
{
|
|
data.post(nif);
|
|
}
|
|
|
|
void NiBoolInterpolator::read(NIFStream *nif)
|
|
{
|
|
defaultVal = nif->getBoolean();
|
|
data.read(nif);
|
|
}
|
|
|
|
void NiBoolInterpolator::post(NIFFile *nif)
|
|
{
|
|
data.post(nif);
|
|
}
|
|
|
|
void NiFloatInterpolator::read(NIFStream *nif)
|
|
{
|
|
defaultVal = nif->getFloat();
|
|
data.read(nif);
|
|
}
|
|
|
|
void NiFloatInterpolator::post(NIFFile *nif)
|
|
{
|
|
data.post(nif);
|
|
}
|
|
|
|
void NiTransformInterpolator::read(NIFStream *nif)
|
|
{
|
|
defaultPos = nif->getVector3();
|
|
defaultRot = nif->getQuaternion();
|
|
defaultScale = nif->getFloat();
|
|
if (nif->getVersion() <= NIFStream::generateVersion(10,1,0,109))
|
|
{
|
|
if (!nif->getBoolean())
|
|
defaultPos = osg::Vec3f();
|
|
if (!nif->getBoolean())
|
|
defaultRot = osg::Quat();
|
|
if (!nif->getBoolean())
|
|
defaultScale = 1.f;
|
|
}
|
|
data.read(nif);
|
|
}
|
|
|
|
void NiTransformInterpolator::post(NIFFile *nif)
|
|
{
|
|
data.post(nif);
|
|
}
|
|
|
|
void NiColorInterpolator::read(NIFStream *nif)
|
|
{
|
|
defaultVal = nif->getVector4();
|
|
data.read(nif);
|
|
}
|
|
|
|
void NiColorInterpolator::post(NIFFile *nif)
|
|
{
|
|
data.post(nif);
|
|
}
|
|
|
|
}
|