1 // NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
2 // Copyright (C) 2010 Winch Gate Property Limited
4 // This program is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU Affero General Public License as
6 // published by the Free Software Foundation, either version 3 of the
7 // License, or (at your option) any later version.
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU Affero General Public License for more details.
14 // You should have received a copy of the GNU Affero General Public License
15 // along with this program. If not, see <http://www.gnu.org/licenses/>.
21 #include <nel/misc/types_nl.h>
30 using namespace NLMISC
;
34 // -- -- this file exists twice
36 CVector
CTrajectory::eval(NLMISC::TLocalTime t
) const
38 if (t
< _StartTime
) return _StartPosition
;
40 float ft
= (float)(t
-_StartTime
)/(float)(_StopTime
-_StartTime
);
42 CVector res
= _EndPosition
*ft
+ _StartPosition
*(1.0f
-ft
);
43 res
.z
+= 0.3f
*_Distance
*_Distance
/90.0f
*(float)sin(Pi
*ft
);
47 CVector
CTrajectory::evalSpeed(NLMISC::TLocalTime t
) const
49 if (t
< _StartTime
) return _StartPosition
;
51 float ft
= (float)(t
-_StartTime
)/(float)(_StopTime
-_StartTime
);
53 CVector res
= (_EndPosition
-_StartPosition
).normed()*_Speed
;
54 res
.z
+= 0.3f
*_Distance
*_Distance
/90.0f
*(float)Pi
*(float)cos(Pi
*ft
);
58 } /* namespace SBCLIENT */