| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- /*
- * AnimationTarget.cpp
- */
- #include "Base.h"
- #include "AnimationTarget.h"
- #include "Animation.h"
- #include "Game.h"
- #include <string.h>
- #include "Transform.h"
- namespace gameplay
- {
- AnimationTarget::AnimationTarget()
- : _targetType(SCALAR), _activeAnimationCount(0), _animations(NULL)
- {
- }
- AnimationTarget::~AnimationTarget()
- {
- if (_animations)
- {
- std::vector<Animation*>::iterator animationIter = _animations->begin();
- while (animationIter != _animations->end())
- {
- SAFE_RELEASE((*animationIter));
- animationIter++;
- }
- SAFE_DELETE(_animations);
- }
- }
- void AnimationTarget::addAnimation(Animation* animation)
- {
- if (_animations == NULL)
- {
- _animations = new std::vector<Animation*>;
- }
- _animations->push_back(animation);
- animation->addRef();
- }
- unsigned int AnimationTarget::getAnimationCount() const
- {
- if (_animations)
- return _animations->size();
- return 0;
- }
- Animation* AnimationTarget::getAnimation(unsigned int index) const
- {
- if (_animations)
- return _animations->at(index);
- else
- return 0;
- }
- Animation* AnimationTarget::getAnimation(const char* id) const
- {
- if (_animations)
- {
- std::vector<Animation*>::iterator animationIter = _animations->begin();
- while(animationIter != _animations->end())
- {
- if ((*animationIter)->_id.compare(id) == 0)
- {
- return *animationIter;
- }
- animationIter++;
- }
- }
-
- return NULL;
- }
- void AnimationTarget::increaseActiveAnimationCount()
- {
- _activeAnimationCount++;
- }
- void AnimationTarget::decreaseActiveAnimationCount()
- {
- _activeAnimationCount--;
- }
- unsigned int AnimationTarget::getActiveAnimationCount() const
- {
- return _activeAnimationCount;
- }
- }
|