diff options
author | Kelly Rauchenberger <fefferburbia@gmail.com> | 2018-05-17 15:55:37 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-17 15:55:37 -0400 |
commit | 90aadf3844386824140a20d7fbb847bc16009a94 (patch) | |
tree | 6f83fce90e71abb22b1a8f3e09c79963b2a34d5d /src/animation.cpp | |
parent | bc63fa57ced1c7329f7fdcfd168eaf7e290158bc (diff) | |
parent | 86f0106d0523825549f1e74b835688c78a10cf6c (diff) | |
download | therapy-90aadf3844386824140a20d7fbb847bc16009a94.tar.gz therapy-90aadf3844386824140a20d7fbb847bc16009a94.tar.bz2 therapy-90aadf3844386824140a20d7fbb847bc16009a94.zip |
Merge pull request #7 from hatkirby/es-rewrite
The ECS rewrite exceeds the original branch in functionality, so it is time to merge it in.
Diffstat (limited to 'src/animation.cpp')
-rw-r--r-- | src/animation.cpp | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/src/animation.cpp b/src/animation.cpp new file mode 100644 index 0000000..31ba21f --- /dev/null +++ b/src/animation.cpp | |||
@@ -0,0 +1,35 @@ | |||
1 | #include "animation.h" | ||
2 | |||
3 | AnimationSet::AnimationSet( | ||
4 | Texture texture, | ||
5 | int frameWidth, | ||
6 | int frameHeight, | ||
7 | int framesAcross) : | ||
8 | texture_(std::move(texture)), | ||
9 | frameWidth_(frameWidth), | ||
10 | frameHeight_(frameHeight), | ||
11 | framesAcross_(framesAcross) | ||
12 | { | ||
13 | } | ||
14 | |||
15 | void AnimationSet::emplaceAnimation( | ||
16 | std::string animation, | ||
17 | size_t firstFrame, | ||
18 | size_t numFrames, | ||
19 | size_t delay) | ||
20 | { | ||
21 | animations_.emplace( | ||
22 | std::piecewise_construct, | ||
23 | std::make_tuple(animation), | ||
24 | std::make_tuple(firstFrame, numFrames, delay)); | ||
25 | } | ||
26 | |||
27 | Rectangle AnimationSet::getFrameRect(int frame) const | ||
28 | { | ||
29 | return { | ||
30 | frameWidth_ * (frame % framesAcross_), | ||
31 | frameHeight_ * (frame / framesAcross_), | ||
32 | frameWidth_, | ||
33 | frameHeight_ | ||
34 | }; | ||
35 | } | ||