blob: 9476750afd52e18cb60a3b5584b6763d2f7c167a [file] [log] [blame]
John Recke45b1fd2014-04-15 09:50:16 -07001/*
2 * Copyright (C) 2014 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#ifndef ANIMATOR_H
17#define ANIMATOR_H
18
Chris Craik51d6a3d2014-12-22 17:16:56 -080019#include <memory>
John Recke45b1fd2014-04-15 09:50:16 -070020#include <cutils/compiler.h>
John Reck9fa40712014-05-09 15:26:59 -070021#include <utils/RefBase.h>
John Reck52244ff2014-05-01 21:27:37 -070022#include <utils/StrongPointer.h>
Tom Hudson2dc236b2014-10-15 15:46:42 -040023#include <utils/Timers.h>
John Recke45b1fd2014-04-15 09:50:16 -070024
John Reck52244ff2014-05-01 21:27:37 -070025#include "utils/Macros.h"
John Recke45b1fd2014-04-15 09:50:16 -070026
Doris Liuc4bb1852016-02-19 21:39:21 +000027#include <vector>
28
John Recke45b1fd2014-04-15 09:50:16 -070029namespace android {
30namespace uirenderer {
31
John Reck119907c2014-08-14 09:02:01 -070032class AnimationContext;
33class BaseRenderNodeAnimator;
Tom Hudson2dc236b2014-10-15 15:46:42 -040034class CanvasPropertyPrimitive;
35class CanvasPropertyPaint;
36class Interpolator;
John Reck52244ff2014-05-01 21:27:37 -070037class RenderNode;
John Recke45b1fd2014-04-15 09:50:16 -070038class RenderProperties;
John Recke45b1fd2014-04-15 09:50:16 -070039
John Reck52244ff2014-05-01 21:27:37 -070040class AnimationListener : public VirtualLightRefBase {
41public:
John Reckff941dc2014-05-14 16:34:14 -070042 ANDROID_API virtual void onAnimationFinished(BaseRenderNodeAnimator*) = 0;
John Reck52244ff2014-05-01 21:27:37 -070043protected:
44 ANDROID_API virtual ~AnimationListener() {}
45};
46
John Reckff941dc2014-05-14 16:34:14 -070047class BaseRenderNodeAnimator : public VirtualLightRefBase {
48 PREVENT_COPY_AND_ASSIGN(BaseRenderNodeAnimator);
John Reck52244ff2014-05-01 21:27:37 -070049public:
John Reckc6b32642014-06-02 11:00:09 -070050 ANDROID_API void setStartValue(float value);
John Reck52244ff2014-05-01 21:27:37 -070051 ANDROID_API void setInterpolator(Interpolator* interpolator);
52 ANDROID_API void setDuration(nsecs_t durationInMs);
John Reck315c3292014-05-09 19:21:04 -070053 ANDROID_API nsecs_t duration() { return mDuration; }
Alan Viverettead2f8e32014-05-16 13:28:33 -070054 ANDROID_API void setStartDelay(nsecs_t startDelayInMs);
55 ANDROID_API nsecs_t startDelay() { return mStartDelay; }
John Reck52244ff2014-05-01 21:27:37 -070056 ANDROID_API void setListener(AnimationListener* listener) {
57 mListener = listener;
58 }
John Reck119907c2014-08-14 09:02:01 -070059 AnimationListener* listener() { return mListener.get(); }
John Reckf5945a02014-09-05 15:57:47 -070060 ANDROID_API void setAllowRunningAsync(bool mayRunAsync) {
61 mMayRunAsync = mayRunAsync;
62 }
63 bool mayRunAsync() { return mMayRunAsync; }
Doris Liuc4bb1852016-02-19 21:39:21 +000064 ANDROID_API void start();
Doris Liu718cd3e2016-05-17 16:50:31 -070065 ANDROID_API virtual void reset();
Doris Liuc4bb1852016-02-19 21:39:21 +000066 ANDROID_API void reverse();
67 // Terminates the animation at its current progress.
68 ANDROID_API void cancel();
69
70 // Terminates the animation and skip to the end of the animation.
Doris Liu718cd3e2016-05-17 16:50:31 -070071 ANDROID_API virtual void end();
John Reck52244ff2014-05-01 21:27:37 -070072
John Reck8d8af3c2014-07-01 15:23:45 -070073 void attach(RenderNode* target);
74 virtual void onAttached() {}
Chris Craikd41c4d82015-01-05 15:51:13 -080075 void detach() { mTarget = nullptr; }
Doris Liu718cd3e2016-05-17 16:50:31 -070076 ANDROID_API void pushStaging(AnimationContext& context);
77 ANDROID_API bool animate(AnimationContext& context);
78
79 // Returns the remaining time in ms for the animation. Note this should only be called during
80 // an animation on RenderThread.
81 ANDROID_API nsecs_t getRemainingPlayTime();
John Reckff941dc2014-05-14 16:34:14 -070082
Doris Liuc4bb1852016-02-19 21:39:21 +000083 bool isRunning() { return mPlayState == PlayState::Running
84 || mPlayState == PlayState::Reversing; }
Chris Craikb9ce116d2015-08-20 15:14:06 -070085 bool isFinished() { return mPlayState == PlayState::Finished; }
John Reckff941dc2014-05-14 16:34:14 -070086 float finalValue() { return mFinalValue; }
John Reck52244ff2014-05-01 21:27:37 -070087
John Recka7c2ea22014-08-08 13:21:00 -070088 ANDROID_API virtual uint32_t dirtyMask() = 0;
John Reck22184722014-06-20 07:19:30 -070089
John Recke2478d42014-09-03 16:46:05 -070090 void forceEndNow(AnimationContext& context);
Doris Liuc4bb1852016-02-19 21:39:21 +000091 RenderNode* target() { return mTarget; }
Doris Liu8b083202016-02-19 21:46:06 +000092 RenderNode* stagingTarget() { return mStagingTarget; }
John Recke2478d42014-09-03 16:46:05 -070093
John Reck52244ff2014-05-01 21:27:37 -070094protected:
Doris Liu766431a2016-02-04 22:17:11 +000095 // PlayState is used by mStagingPlayState and mPlayState to track the state initiated from UI
96 // thread and Render Thread animation state, respectively.
97 // From the UI thread, mStagingPlayState transition looks like
Doris Liuc4bb1852016-02-19 21:39:21 +000098 // NotStarted -> Running/Reversing -> Finished
99 // ^ |
100 // | |
101 // ----------------------
Doris Liu766431a2016-02-04 22:17:11 +0000102 // Note: For mStagingState, the Finished state (optional) is only set when the animation is
103 // terminated by user.
104 //
105 // On Render Thread, mPlayState transition:
Doris Liuc4bb1852016-02-19 21:39:21 +0000106 // NotStart -> Running/Reversing-> Finished
107 // ^ |
108 // | |
109 // ------------------
110 // Note that if the animation is in Running/Reversing state, calling start or reverse again
111 // would do nothing if the animation has the same play direction as the request; otherwise,
112 // the animation would start from where it is and change direction (i.e. Reversing <-> Running)
Doris Liu766431a2016-02-04 22:17:11 +0000113
Chris Craikb9ce116d2015-08-20 15:14:06 -0700114 enum class PlayState {
115 NotStarted,
116 Running,
Doris Liuc4bb1852016-02-19 21:39:21 +0000117 Reversing,
Chris Craikb9ce116d2015-08-20 15:14:06 -0700118 Finished,
119 };
120
John Reckff941dc2014-05-14 16:34:14 -0700121 BaseRenderNodeAnimator(float finalValue);
122 virtual ~BaseRenderNodeAnimator();
John Reck52244ff2014-05-01 21:27:37 -0700123
John Reckff941dc2014-05-14 16:34:14 -0700124 virtual float getValue(RenderNode* target) const = 0;
125 virtual void setValue(RenderNode* target, float value) = 0;
John Reck52244ff2014-05-01 21:27:37 -0700126
John Reck119907c2014-08-14 09:02:01 -0700127 void callOnFinishedListener(AnimationContext& context);
John Reck52244ff2014-05-01 21:27:37 -0700128
John Reck8d8af3c2014-07-01 15:23:45 -0700129 virtual void onStagingPlayStateChanged() {}
Doris Liu766431a2016-02-04 22:17:11 +0000130 virtual void onPlayTimeChanged(nsecs_t playTime) {}
Doris Liu8b083202016-02-19 21:46:06 +0000131 virtual void onPushStaging() {}
John Reck8d8af3c2014-07-01 15:23:45 -0700132
John Reck8d8af3c2014-07-01 15:23:45 -0700133 RenderNode* mTarget;
Doris Liu8b083202016-02-19 21:46:06 +0000134 RenderNode* mStagingTarget;
John Reck8d8af3c2014-07-01 15:23:45 -0700135
John Reckff941dc2014-05-14 16:34:14 -0700136 float mFinalValue;
137 float mDeltaValue;
138 float mFromValue;
139
Chris Craik51d6a3d2014-12-22 17:16:56 -0800140 std::unique_ptr<Interpolator> mInterpolator;
John Reck68bfe0a2014-06-24 15:34:58 -0700141 PlayState mStagingPlayState;
John Reck52244ff2014-05-01 21:27:37 -0700142 PlayState mPlayState;
John Reck68bfe0a2014-06-24 15:34:58 -0700143 bool mHasStartValue;
Alan Viverettead2f8e32014-05-16 13:28:33 -0700144 nsecs_t mStartTime;
Alan Viverettead2f8e32014-05-16 13:28:33 -0700145 nsecs_t mDuration;
146 nsecs_t mStartDelay;
John Reckf5945a02014-09-05 15:57:47 -0700147 bool mMayRunAsync;
Doris Liuc4bb1852016-02-19 21:39:21 +0000148 // Play Time tracks the progress of animation, it should always be [0, mDuration], 0 being
149 // the beginning of the animation, will reach mDuration at the end of an animation.
150 nsecs_t mPlayTime;
John Reck52244ff2014-05-01 21:27:37 -0700151
Alan Viverettead2f8e32014-05-16 13:28:33 -0700152 sp<AnimationListener> mListener;
John Reck68bfe0a2014-06-24 15:34:58 -0700153
154private:
Doris Liuc4bb1852016-02-19 21:39:21 +0000155 enum class Request {
156 Start,
157 Reverse,
158 Reset,
159 Cancel,
160 End
161 };
John Reck68bfe0a2014-06-24 15:34:58 -0700162 inline void checkMutable();
John Reck119907c2014-08-14 09:02:01 -0700163 virtual void transitionToRunning(AnimationContext& context);
John Reck8d8af3c2014-07-01 15:23:45 -0700164 void doSetStartValue(float value);
Doris Liuc4bb1852016-02-19 21:39:21 +0000165 bool updatePlayTime(nsecs_t playTime);
166 void resolveStagingRequest(Request request);
167
168 std::vector<Request> mStagingRequests;
169
John Reck52244ff2014-05-01 21:27:37 -0700170};
171
John Reck52244ff2014-05-01 21:27:37 -0700172class RenderPropertyAnimator : public BaseRenderNodeAnimator {
173public:
John Recke45b1fd2014-04-15 09:50:16 -0700174 enum RenderProperty {
175 TRANSLATION_X = 0,
176 TRANSLATION_Y,
177 TRANSLATION_Z,
178 SCALE_X,
179 SCALE_Y,
180 ROTATION,
181 ROTATION_X,
182 ROTATION_Y,
183 X,
184 Y,
185 Z,
186 ALPHA,
187 };
188
John Reckff941dc2014-05-14 16:34:14 -0700189 ANDROID_API RenderPropertyAnimator(RenderProperty property, float finalValue);
190
John Reck22184722014-06-20 07:19:30 -0700191 ANDROID_API virtual uint32_t dirtyMask();
192
John Recke45b1fd2014-04-15 09:50:16 -0700193protected:
Chris Craikd41c4d82015-01-05 15:51:13 -0800194 virtual float getValue(RenderNode* target) const override;
195 virtual void setValue(RenderNode* target, float value) override;
196 virtual void onAttached() override;
197 virtual void onStagingPlayStateChanged() override;
Doris Liu8b083202016-02-19 21:46:06 +0000198 virtual void onPushStaging() override;
John Recke45b1fd2014-04-15 09:50:16 -0700199
200private:
John Reck79c7de72014-05-23 10:33:31 -0700201 typedef bool (RenderProperties::*SetFloatProperty)(float value);
John Reck52244ff2014-05-01 21:27:37 -0700202 typedef float (RenderProperties::*GetFloatProperty)() const;
203
John Reckff941dc2014-05-14 16:34:14 -0700204 struct PropertyAccessors;
205 const PropertyAccessors* mPropertyAccess;
John Reck52244ff2014-05-01 21:27:37 -0700206
207 static const PropertyAccessors PROPERTY_ACCESSOR_LUT[];
Doris Liu8b083202016-02-19 21:46:06 +0000208 bool mShouldSyncPropertyFields = false;
209 bool mShouldUpdateStagingProperties = false;
John Reck52244ff2014-05-01 21:27:37 -0700210};
211
212class CanvasPropertyPrimitiveAnimator : public BaseRenderNodeAnimator {
213public:
214 ANDROID_API CanvasPropertyPrimitiveAnimator(CanvasPropertyPrimitive* property,
John Reckff941dc2014-05-14 16:34:14 -0700215 float finalValue);
John Recka7c2ea22014-08-08 13:21:00 -0700216
217 ANDROID_API virtual uint32_t dirtyMask();
218
John Reck52244ff2014-05-01 21:27:37 -0700219protected:
Chris Craikd41c4d82015-01-05 15:51:13 -0800220 virtual float getValue(RenderNode* target) const override;
221 virtual void setValue(RenderNode* target, float value) override;
John Reck52244ff2014-05-01 21:27:37 -0700222private:
223 sp<CanvasPropertyPrimitive> mProperty;
224};
225
226class CanvasPropertyPaintAnimator : public BaseRenderNodeAnimator {
227public:
228 enum PaintField {
229 STROKE_WIDTH = 0,
230 ALPHA,
231 };
232
233 ANDROID_API CanvasPropertyPaintAnimator(CanvasPropertyPaint* property,
John Reckff941dc2014-05-14 16:34:14 -0700234 PaintField field, float finalValue);
John Recka7c2ea22014-08-08 13:21:00 -0700235
236 ANDROID_API virtual uint32_t dirtyMask();
237
John Reck52244ff2014-05-01 21:27:37 -0700238protected:
Chris Craikd41c4d82015-01-05 15:51:13 -0800239 virtual float getValue(RenderNode* target) const override;
240 virtual void setValue(RenderNode* target, float value) override;
John Reck52244ff2014-05-01 21:27:37 -0700241private:
242 sp<CanvasPropertyPaint> mProperty;
243 PaintField mField;
John Recke45b1fd2014-04-15 09:50:16 -0700244};
245
John Reckd3de42c2014-07-15 14:29:33 -0700246class RevealAnimator : public BaseRenderNodeAnimator {
247public:
Chris Craikaf4d04c2014-07-29 12:50:14 -0700248 ANDROID_API RevealAnimator(int centerX, int centerY,
John Reckd3de42c2014-07-15 14:29:33 -0700249 float startValue, float finalValue);
John Recka7c2ea22014-08-08 13:21:00 -0700250
251 ANDROID_API virtual uint32_t dirtyMask();
252
John Reckd3de42c2014-07-15 14:29:33 -0700253protected:
Chris Craikd41c4d82015-01-05 15:51:13 -0800254 virtual float getValue(RenderNode* target) const override;
255 virtual void setValue(RenderNode* target, float value) override;
John Reckd3de42c2014-07-15 14:29:33 -0700256
257private:
258 int mCenterX, mCenterY;
John Reckd3de42c2014-07-15 14:29:33 -0700259};
260
John Recke45b1fd2014-04-15 09:50:16 -0700261} /* namespace uirenderer */
262} /* namespace android */
263
264#endif /* ANIMATOR_H */