2002-02-27 08:58:54 +08:00
|
|
|
#include <osg/AnimationPath>
|
2002-04-22 06:05:26 +08:00
|
|
|
#include <osg/NodeVisitor>
|
2002-02-27 08:58:54 +08:00
|
|
|
|
|
|
|
using namespace osg;
|
|
|
|
|
|
|
|
void AnimationPath::insert(double time,const Key& key)
|
|
|
|
{
|
|
|
|
_timeKeyMap[time] = key;
|
|
|
|
}
|
|
|
|
|
2002-04-22 06:05:26 +08:00
|
|
|
bool AnimationPath::getMatrix(double time,Matrix& matrix) const
|
2002-02-27 08:58:54 +08:00
|
|
|
{
|
|
|
|
if (_timeKeyMap.empty()) return false;
|
|
|
|
|
2002-04-22 06:05:26 +08:00
|
|
|
TimeKeyMap::const_iterator second = _timeKeyMap.lower_bound(time);
|
2002-02-27 08:58:54 +08:00
|
|
|
if (second==_timeKeyMap.begin())
|
|
|
|
{
|
|
|
|
second->second.getMatrix(matrix);
|
|
|
|
}
|
|
|
|
else if (second!=_timeKeyMap.end())
|
|
|
|
{
|
2002-04-22 06:05:26 +08:00
|
|
|
TimeKeyMap::const_iterator first = second;
|
2002-02-27 08:58:54 +08:00
|
|
|
--first;
|
|
|
|
|
|
|
|
// we have both a lower bound and the next item.
|
|
|
|
|
|
|
|
// deta_time = second.time - first.time
|
|
|
|
double delta_time = second->first - first->first;
|
|
|
|
|
|
|
|
if (delta_time==0.0)
|
|
|
|
first->second.getMatrix(matrix);
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Key key;
|
|
|
|
key.interpolate((time - first->first)/delta_time,
|
|
|
|
first->second,
|
|
|
|
second->second);
|
|
|
|
key.getMatrix(matrix);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else // (second==_timeKeyMap.end())
|
|
|
|
{
|
|
|
|
_timeKeyMap.rbegin().base()->second.getMatrix(matrix);
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2002-04-22 06:05:26 +08:00
|
|
|
bool AnimationPath::getInverse(double time,Matrix& matrix) const
|
2002-02-27 08:58:54 +08:00
|
|
|
{
|
2002-03-01 17:29:56 +08:00
|
|
|
if (_timeKeyMap.empty()) return false;
|
|
|
|
|
2002-04-22 06:05:26 +08:00
|
|
|
TimeKeyMap::const_iterator second = _timeKeyMap.lower_bound(time);
|
2002-03-01 17:29:56 +08:00
|
|
|
if (second==_timeKeyMap.begin())
|
|
|
|
{
|
|
|
|
second->second.getInverse(matrix);
|
|
|
|
}
|
|
|
|
else if (second!=_timeKeyMap.end())
|
|
|
|
{
|
2002-04-22 06:05:26 +08:00
|
|
|
TimeKeyMap::const_iterator first = second;
|
2002-03-01 17:29:56 +08:00
|
|
|
--first;
|
|
|
|
|
|
|
|
// we have both a lower bound and the next item.
|
|
|
|
|
|
|
|
// deta_time = second.time - first.time
|
|
|
|
double delta_time = second->first - first->first;
|
|
|
|
|
|
|
|
if (delta_time==0.0)
|
|
|
|
first->second.getInverse(matrix);
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Key key;
|
|
|
|
key.interpolate((time - first->first)/delta_time,
|
|
|
|
first->second,
|
|
|
|
second->second);
|
|
|
|
key.getInverse(matrix);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else // (second==_timeKeyMap.end())
|
|
|
|
{
|
|
|
|
_timeKeyMap.rbegin().base()->second.getInverse(matrix);
|
|
|
|
}
|
|
|
|
return true;
|
2002-02-27 08:58:54 +08:00
|
|
|
}
|
2002-04-22 06:05:26 +08:00
|
|
|
|
|
|
|
const bool AnimationPath::computeLocalToWorldMatrix(Matrix& matrix,const Transform*, NodeVisitor* nv) const
|
|
|
|
{
|
|
|
|
if (nv)
|
|
|
|
{
|
|
|
|
const osg::FrameStamp* fs = nv->getFrameStamp();
|
|
|
|
if (fs)
|
|
|
|
{
|
|
|
|
osg::Matrix localMatrix;
|
|
|
|
getMatrix(fs->getReferenceTime(),localMatrix);
|
|
|
|
matrix.preMult(localMatrix);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Get the transformation matrix which moves from world coords to local coords.*/
|
|
|
|
const bool AnimationPath::computeWorldToLocalMatrix(Matrix& matrix,const Transform* , NodeVisitor* nv) const
|
|
|
|
{
|
|
|
|
if (nv)
|
|
|
|
{
|
|
|
|
const osg::FrameStamp* fs = nv->getFrameStamp();
|
|
|
|
if (fs)
|
|
|
|
{
|
|
|
|
osg::Matrix localInverse;
|
|
|
|
getInverse(fs->getReferenceTime(),localInverse);
|
|
|
|
matrix.postMult(localInverse);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|