114 lines
2.9 KiB
C
114 lines
2.9 KiB
C
|
// NeL - MMORPG Framework <http://dev.ryzom.com/projects/nel/>
|
||
|
// Copyright (C) 2010 Winch Gate Property Limited
|
||
|
//
|
||
|
// This program is free software: you can redistribute it and/or modify
|
||
|
// it under the terms of the GNU Affero General Public License as
|
||
|
// published by the Free Software Foundation, either version 3 of the
|
||
|
// License, or (at your option) any later version.
|
||
|
//
|
||
|
// This program is distributed in the hope that it will be useful,
|
||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
// GNU Affero General Public License for more details.
|
||
|
//
|
||
|
// You should have received a copy of the GNU Affero General Public License
|
||
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
|
|
||
|
#ifndef NL_U_ANIMATION_H
|
||
|
#define NL_U_ANIMATION_H
|
||
|
|
||
|
#include "nel/misc/types_nl.h"
|
||
|
|
||
|
|
||
|
namespace NL3D
|
||
|
{
|
||
|
|
||
|
class UTrack;
|
||
|
|
||
|
/**
|
||
|
* Give manual access to the animation functions.
|
||
|
*
|
||
|
* By this interface, you can load animations, get tracks from this animation
|
||
|
* with there names, and interpolate manually value from those tracks.
|
||
|
*
|
||
|
* This interface is not made to work with UAnimationSet or UPlayList.
|
||
|
* UAnimation has its own methods to load / release animations.
|
||
|
*
|
||
|
* \author Cyril 'Hulud' Corvazier
|
||
|
* \author Nevrax France
|
||
|
* \date 2001
|
||
|
*/
|
||
|
class UAnimation
|
||
|
{
|
||
|
public:
|
||
|
virtual ~UAnimation() {}
|
||
|
|
||
|
/// \name Create / delete animations
|
||
|
// @{
|
||
|
|
||
|
/**
|
||
|
* Load an animation. This method will use CPath to find the good
|
||
|
* animation file. (*.anim). You should call releaseAnimation
|
||
|
* to delete the animation.
|
||
|
*
|
||
|
* \param sPath is the animation file path.
|
||
|
* \return NULL if the file is not found. Else return the pointer on the
|
||
|
* animation interface.
|
||
|
*/
|
||
|
static UAnimation* createAnimation (const char* sPath);
|
||
|
|
||
|
/**
|
||
|
* Release an animation. This animation must have been created will createAnimation().
|
||
|
*
|
||
|
* \param animation is the animation to release.
|
||
|
*/
|
||
|
static void releaseAnimation (UAnimation* animation);
|
||
|
|
||
|
// @}
|
||
|
|
||
|
/**
|
||
|
* Get an animation track with its name. The track interface should be released
|
||
|
* with releaseTrack.
|
||
|
*
|
||
|
* \param name is the name of the track to get.
|
||
|
* \return NULL if the track is not found, else a pointer on the track interface.
|
||
|
*/
|
||
|
virtual UTrack* getTrackByName (const char* name) =0;
|
||
|
|
||
|
/**
|
||
|
* Relase a track interface.
|
||
|
*
|
||
|
* \param track is a pointer on the track interface to release.
|
||
|
*/
|
||
|
virtual void releaseTrack (UTrack* track) =0;
|
||
|
|
||
|
/**
|
||
|
* Get begin time of the animation.
|
||
|
*
|
||
|
* \return the begin time.
|
||
|
*/
|
||
|
virtual TAnimationTime getBeginTime () const =0;
|
||
|
|
||
|
/**
|
||
|
* Get end time of the animation.
|
||
|
*
|
||
|
* \return the end time.
|
||
|
*/
|
||
|
virtual TAnimationTime getEndTime () const =0;
|
||
|
|
||
|
/**
|
||
|
* Say if all track of this animation loop.
|
||
|
* NB: If no tracks in the animation, return true
|
||
|
*/
|
||
|
virtual bool allTrackLoop() const =0;
|
||
|
|
||
|
};
|
||
|
|
||
|
|
||
|
} // NL3D
|
||
|
|
||
|
|
||
|
#endif // NL_U_ANIMATION_H
|
||
|
|
||
|
/* End of u_animation.h */
|