2021-10-02 21:17:03 +03:00
|
|
|
//
|
|
|
|
// Created by Иван Ильин on 03.10.2021.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include <list>
|
|
|
|
#include "Animation.h"
|
2021-10-17 10:21:10 +03:00
|
|
|
#include "Timeline.h"
|
2021-10-02 21:17:03 +03:00
|
|
|
|
|
|
|
namespace Timeline {
|
|
|
|
namespace {
|
2021-10-17 10:21:10 +03:00
|
|
|
std::map<AnimationListTag, std::list<Animation*>> _animations;
|
2021-10-02 21:17:03 +03:00
|
|
|
}
|
|
|
|
|
2021-10-17 10:21:10 +03:00
|
|
|
void animate(const AnimationListTag& listName, Animation* anim) {
|
2021-10-02 21:17:03 +03:00
|
|
|
_animations[listName].emplace_back(anim);
|
|
|
|
}
|
|
|
|
|
|
|
|
void deleteAllAnimations() {
|
|
|
|
_animations.clear();
|
|
|
|
}
|
|
|
|
|
2021-10-17 10:21:10 +03:00
|
|
|
void deleteAnimationList(const AnimationListTag& listName) {
|
2021-10-02 21:17:03 +03:00
|
|
|
_animations[listName].clear();
|
|
|
|
_animations.erase(listName);
|
|
|
|
}
|
|
|
|
|
2021-10-17 10:21:10 +03:00
|
|
|
[[nodiscard]] bool isInAnimList(const AnimationListTag& listName) {
|
|
|
|
return !_animations[listName].empty();
|
2021-10-02 21:17:03 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void update() {
|
|
|
|
for (auto& [listName, animationList] : _animations) {
|
|
|
|
|
|
|
|
if (animationList.empty())
|
|
|
|
continue;
|
|
|
|
auto it = animationList.begin();
|
|
|
|
// If it the front animation is 'a_wait()' we should wait until waiting time is over
|
|
|
|
|
|
|
|
if (it.operator*()->waitFor()) {
|
|
|
|
if (!it.operator*()->update())
|
|
|
|
animationList.erase(it);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Otherwise we iterate over all animation until we meet animations.end() or wait animation
|
|
|
|
while (!animationList.empty() && (it != animationList.end()) && (!it.operator*()->waitFor())) {
|
|
|
|
if (!it.operator*()->update())
|
|
|
|
animationList.erase(it++);
|
|
|
|
else
|
|
|
|
it++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|