|
|
@ -18,50 +18,59 @@
|
|
|
|
namespace NifOsg
|
|
|
|
namespace NifOsg
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
ControllerFunction::ControllerFunction(const Nif::Controller *ctrl, bool deltaInput)
|
|
|
|
ControllerFunction::ControllerFunction(const Nif::Controller *ctrl)
|
|
|
|
: mDeltaInput(deltaInput)
|
|
|
|
: mFrequency(ctrl->frequency)
|
|
|
|
, mFrequency(ctrl->frequency)
|
|
|
|
|
|
|
|
, mPhase(ctrl->phase)
|
|
|
|
, mPhase(ctrl->phase)
|
|
|
|
, mStartTime(ctrl->timeStart)
|
|
|
|
, mStartTime(ctrl->timeStart)
|
|
|
|
, mStopTime(ctrl->timeStop)
|
|
|
|
, mStopTime(ctrl->timeStop)
|
|
|
|
, mDeltaCount(0.f)
|
|
|
|
, mExtrapolationMode(static_cast<ExtrapolationMode>((ctrl->flags&0x6) >> 1))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(mDeltaInput)
|
|
|
|
|
|
|
|
mDeltaCount = mPhase;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float ControllerFunction::calculate(float value)
|
|
|
|
float ControllerFunction::calculate(float value)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(mDeltaInput)
|
|
|
|
float time = mFrequency * value + mPhase;
|
|
|
|
|
|
|
|
if (time >= mStartTime && time <= mStopTime)
|
|
|
|
|
|
|
|
return time;
|
|
|
|
|
|
|
|
switch (mExtrapolationMode)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (mStopTime - mStartTime == 0.f)
|
|
|
|
case Cycle:
|
|
|
|
return 0.f;
|
|
|
|
{
|
|
|
|
|
|
|
|
float delta = mStopTime - mStartTime;
|
|
|
|
mDeltaCount += value*mFrequency;
|
|
|
|
if ( delta <= 0 )
|
|
|
|
if(mDeltaCount < mStartTime)
|
|
|
|
return mStartTime;
|
|
|
|
mDeltaCount = mStopTime - std::fmod(mStartTime - mDeltaCount,
|
|
|
|
float cycles = ( time - mStartTime ) / delta;
|
|
|
|
mStopTime - mStartTime);
|
|
|
|
float remainder = ( cycles - std::floor( cycles ) ) * delta;
|
|
|
|
mDeltaCount = std::fmod(mDeltaCount - mStartTime,
|
|
|
|
return mStartTime + remainder;
|
|
|
|
mStopTime - mStartTime) + mStartTime;
|
|
|
|
|
|
|
|
return mDeltaCount;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
case Reverse:
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
float delta = mStopTime - mStartTime;
|
|
|
|
|
|
|
|
if ( delta <= 0 )
|
|
|
|
|
|
|
|
return mStartTime;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
float cycles = ( time - mStartTime ) / delta;
|
|
|
|
|
|
|
|
float remainder = ( cycles - std::floor( cycles ) ) * delta;
|
|
|
|
|
|
|
|
|
|
|
|
value = std::min(mStopTime, std::max(mStartTime, value+mPhase));
|
|
|
|
// Even number of cycles?
|
|
|
|
return value;
|
|
|
|
if ( ( static_cast<int>(std::fabs( std::floor( cycles ) )) % 2 ) == 0 )
|
|
|
|
|
|
|
|
return mStartTime + remainder;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return mStopTime - remainder;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
case Constant:
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
return std::min(mStopTime, std::max(mStartTime, time));
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FrameTimeSource::FrameTimeSource()
|
|
|
|
FrameTimeSource::FrameTimeSource()
|
|
|
|
: mLastTime(0.0)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float FrameTimeSource::getValue(osg::NodeVisitor *nv)
|
|
|
|
float FrameTimeSource::getValue(osg::NodeVisitor *nv)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// TODO: dt could be computed globally instead of once per instance
|
|
|
|
return nv->getFrameStamp()->getReferenceTime();
|
|
|
|
double time = nv->getFrameStamp()->getReferenceTime();
|
|
|
|
|
|
|
|
float dt = static_cast<float>(time - mLastTime);
|
|
|
|
|
|
|
|
mLastTime = time;
|
|
|
|
|
|
|
|
return dt;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
KeyframeController::KeyframeController()
|
|
|
|
KeyframeController::KeyframeController()
|
|
|
|