John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 1 | /* |
| 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 TREEINFO_H |
| 17 | #define TREEINFO_H |
| 18 | |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 19 | #include <utils/Timers.h> |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 20 | |
John Reck | a447d29 | 2014-06-11 18:39:44 -0700 | [diff] [blame^] | 21 | #include "DamageAccumulator.h" |
John Reck | e4267ea | 2014-06-03 15:53:15 -0700 | [diff] [blame] | 22 | #include "utils/Macros.h" |
| 23 | |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 24 | namespace android { |
| 25 | namespace uirenderer { |
| 26 | |
John Reck | ff941dc | 2014-05-14 16:34:14 -0700 | [diff] [blame] | 27 | class BaseRenderNodeAnimator; |
John Reck | 52244ff | 2014-05-01 21:27:37 -0700 | [diff] [blame] | 28 | class AnimationListener; |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 29 | |
John Reck | 52244ff | 2014-05-01 21:27:37 -0700 | [diff] [blame] | 30 | class AnimationHook { |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 31 | public: |
John Reck | ff941dc | 2014-05-14 16:34:14 -0700 | [diff] [blame] | 32 | virtual void callOnFinished(BaseRenderNodeAnimator* animator, AnimationListener* listener) = 0; |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 33 | protected: |
John Reck | 52244ff | 2014-05-01 21:27:37 -0700 | [diff] [blame] | 34 | ~AnimationHook() {} |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 35 | }; |
| 36 | |
John Reck | e4267ea | 2014-06-03 15:53:15 -0700 | [diff] [blame] | 37 | // This would be a struct, but we want to PREVENT_COPY_AND_ASSIGN |
| 38 | class TreeInfo { |
| 39 | PREVENT_COPY_AND_ASSIGN(TreeInfo); |
| 40 | public: |
| 41 | enum TraversalMode { |
| 42 | // The full monty - sync, push, run animators, etc... Used by DrawFrameTask |
| 43 | // May only be used if both the UI thread and RT thread are blocked on the |
| 44 | // prepare |
| 45 | MODE_FULL, |
| 46 | // Run only what can be done safely on RT thread. Currently this only means |
| 47 | // animators, but potentially things like SurfaceTexture updates |
| 48 | // could be handled by this as well if there are no listeners |
| 49 | MODE_RT_ONLY, |
| 50 | // The subtree is being detached. Maybe. If the RenderNode is present |
| 51 | // in both the old and new display list's children then it will get a |
| 52 | // MODE_MAYBE_DETACHING followed shortly by a MODE_FULL. |
| 53 | // Push any pending display list changes in case it is detached, |
| 54 | // but don't evaluate animators and such as if it isn't detached as a |
| 55 | // MODE_FULL will follow shortly. |
| 56 | MODE_MAYBE_DETACHING, |
| 57 | // TODO: TRIM_MEMORY? |
| 58 | }; |
| 59 | |
| 60 | explicit TreeInfo(TraversalMode mode) |
| 61 | : mode(mode) |
| 62 | , frameTimeMs(0) |
John Reck | f9be779 | 2014-05-02 18:21:16 -0700 | [diff] [blame] | 63 | , animationHook(NULL) |
John Reck | e4267ea | 2014-06-03 15:53:15 -0700 | [diff] [blame] | 64 | , prepareTextures(mode == MODE_FULL) |
John Reck | a447d29 | 2014-06-11 18:39:44 -0700 | [diff] [blame^] | 65 | , damageAccumulator(NullDamageAccumulator::instance()) |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 66 | {} |
| 67 | |
John Reck | e4267ea | 2014-06-03 15:53:15 -0700 | [diff] [blame] | 68 | const TraversalMode mode; |
John Reck | f9be779 | 2014-05-02 18:21:16 -0700 | [diff] [blame] | 69 | nsecs_t frameTimeMs; |
| 70 | AnimationHook* animationHook; |
John Reck | e4267ea | 2014-06-03 15:53:15 -0700 | [diff] [blame] | 71 | // TODO: Remove this? Currently this is used to signal to stop preparing |
| 72 | // textures if we run out of cache space. |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 73 | bool prepareTextures; |
John Reck | a447d29 | 2014-06-11 18:39:44 -0700 | [diff] [blame^] | 74 | // Must not be null |
| 75 | IDamageAccumulator* damageAccumulator; |
John Reck | f9be779 | 2014-05-02 18:21:16 -0700 | [diff] [blame] | 76 | |
| 77 | struct Out { |
| 78 | Out() |
| 79 | : hasFunctors(false) |
| 80 | , hasAnimations(false) |
| 81 | , requiresUiRedraw(false) |
John Reck | a5dda64 | 2014-05-22 15:43:54 -0700 | [diff] [blame] | 82 | , canDrawThisFrame(true) |
John Reck | f9be779 | 2014-05-02 18:21:16 -0700 | [diff] [blame] | 83 | {} |
| 84 | bool hasFunctors; |
| 85 | // This is only updated if evaluateAnimations is true |
| 86 | bool hasAnimations; |
| 87 | // This is set to true if there is an animation that RenderThread cannot |
| 88 | // animate itself, such as if hasFunctors is true |
| 89 | // This is only set if hasAnimations is true |
| 90 | bool requiresUiRedraw; |
John Reck | a5dda64 | 2014-05-22 15:43:54 -0700 | [diff] [blame] | 91 | // This is set to true if draw() can be called this frame |
| 92 | // false means that we must delay until the next vsync pulse as frame |
| 93 | // production is outrunning consumption |
| 94 | // NOTE that if this is false CanvasContext will set either requiresUiRedraw |
| 95 | // *OR* will post itself for the next vsync automatically, use this |
| 96 | // only to avoid calling draw() |
| 97 | bool canDrawThisFrame; |
John Reck | f9be779 | 2014-05-02 18:21:16 -0700 | [diff] [blame] | 98 | } out; |
John Reck | e45b1fd | 2014-04-15 09:50:16 -0700 | [diff] [blame] | 99 | |
| 100 | // TODO: Damage calculations |
| 101 | }; |
| 102 | |
| 103 | } /* namespace uirenderer */ |
| 104 | } /* namespace android */ |
| 105 | |
| 106 | #endif /* TREEINFO_H */ |