summaryrefslogtreecommitdiff
path: root/libs/hwui/Layer.cpp
diff options
context:
space:
mode:
author Chris Craik <ccraik@google.com> 2013-06-13 00:37:02 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2013-06-13 00:37:02 +0000
commit149b015db9a478c6345cf0528fe4df3c7c2b5110 (patch)
tree249c56eec7775891208a1c3ed0dc23ada71146c7 /libs/hwui/Layer.cpp
parentaf0fa4fd739aae14733615b6ee9a6b9ca025c628 (diff)
parent28ce94a4ffc7576f40776d212f1ada79fafaa061 (diff)
Merge "Overdraw avoidance and merging of clipped ops"
Diffstat (limited to 'libs/hwui/Layer.cpp')
-rw-r--r--libs/hwui/Layer.cpp14
1 files changed, 8 insertions, 6 deletions
diff --git a/libs/hwui/Layer.cpp b/libs/hwui/Layer.cpp
index 134f452aa4d1..7c22bbb6f973 100644
--- a/libs/hwui/Layer.cpp
+++ b/libs/hwui/Layer.cpp
@@ -188,12 +188,6 @@ void Layer::allocateTexture() {
}
void Layer::defer() {
- if (!deferredList) {
- deferredList = new DeferredDisplayList;
- }
- DeferStateStruct deferredState(*deferredList, *renderer,
- DisplayList::kReplayFlag_ClipChildren);
-
const float width = layer.getWidth();
const float height = layer.getHeight();
@@ -202,6 +196,14 @@ void Layer::defer() {
dirtyRect.set(0, 0, width, height);
}
+ if (deferredList) {
+ deferredList->reset(dirtyRect);
+ } else {
+ deferredList = new DeferredDisplayList(dirtyRect);
+ }
+ DeferStateStruct deferredState(*deferredList, *renderer,
+ DisplayList::kReplayFlag_ClipChildren);
+
renderer->initViewport(width, height);
renderer->setupFrameState(dirtyRect.left, dirtyRect.top,
dirtyRect.right, dirtyRect.bottom, !isBlend());