00001
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026 #include "std3d.h"
00027
00028 #include "nel/misc/common.h"
00029 #include "3d/track_sampled_vector.h"
00030
00031 using namespace NLMISC;
00032 using namespace std;
00033
00034
00035 namespace NL3D
00036 {
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046 CTrackSampledVector::CTrackSampledVector()
00047 {
00048 }
00049
00050
00051 CTrackSampledVector::~CTrackSampledVector()
00052 {
00053 }
00054
00055
00056 const IAnimatedValue& CTrackSampledVector::getValue () const
00057 {
00058 return _Value;
00059 }
00060
00061
00062 void CTrackSampledVector::serial(NLMISC::IStream &f)
00063 {
00064
00065
00066
00067
00068 (void)f.serialVersion(0);
00069
00070
00071 CTrackSampledCommon::serialCommon(f);
00072
00073
00074 f.serial(_Keys);
00075
00076 }
00077
00078
00079 void CTrackSampledVector::build(const std::vector<uint16> &timeList, const std::vector<CVector> &keyList,
00080 float beginTime, float endTime)
00081 {
00082 nlassert( endTime>beginTime || (beginTime==endTime && keyList.size()<=1) );
00083 nlassert( keyList.size()==timeList.size() );
00084 uint i;
00085
00086
00087 uint numKeys= keyList.size();
00088 _Keys.clear();
00089 _TimeBlocks.clear();
00090
00091
00092 CTrackSampledCommon::buildCommon(timeList, beginTime, endTime);
00093
00094
00095
00096
00097 _Keys.resize(numKeys);
00098 for(i=0; i<numKeys;i++)
00099 {
00100
00101 _Keys[i]= keyList[i];
00102 }
00103
00104 }
00105
00106
00107 void CTrackSampledVector::eval (const TAnimationTime& date)
00108 {
00109
00110 uint keyId0;
00111 uint keyId1;
00112 float interpValue;
00113 TEvalType evalType= evalTime(date, _Keys.size(), keyId0, keyId1, interpValue);
00114
00115
00116 if( evalType==EvalDiscard )
00117 return;
00118
00119 else if( evalType==EvalKey0 )
00120 {
00121 _Value.Value= _Keys[keyId0];
00122 }
00123
00124 else if( evalType==EvalInterpolate )
00125 {
00126 const CVector &valueKey0= _Keys[keyId0];
00127 const CVector &valueKey1= _Keys[keyId1];
00128
00129
00130 _Value.Value= valueKey0*(1-interpValue) + valueKey1*interpValue;
00131 }
00132 else
00133 {
00134 nlstop;
00135 }
00136
00137 }
00138
00139
00140 }