diff options
author | Chris Craik <ccraik@google.com> | 2014-06-20 15:03:43 -0700 |
---|---|---|
committer | Chris Craik <ccraik@google.com> | 2014-06-20 16:18:58 -0700 |
commit | 80d4902196899d1325cd9f52c06ae0174cf9bd4c (patch) | |
tree | 659794797f8161ca9580fc17cc5c44bbbe3c304e /libs/hwui/DisplayListOp.h | |
parent | 6b2df21ecacfa6826a85cabdf8d6fe0e81fe11d9 (diff) | |
download | frameworks_base-80d4902196899d1325cd9f52c06ae0174cf9bd4c.zip frameworks_base-80d4902196899d1325cd9f52c06ae0174cf9bd4c.tar.gz frameworks_base-80d4902196899d1325cd9f52c06ae0174cf9bd4c.tar.bz2 |
Wrap ViewGroup content in save/restore to protect composited children
bug:15570351
Pos Z composited children are drawn before the primary restore for a
RenderNode. This means that without an additional save/restore (which
wraps the content) they aren't protected from transformations/clips
that happen within the ViewGroup's DisplayList.
Also changes RenderNode to use OpenGLRenderer tag for displaylist
dumping consistency, and simplifies the entry points into RenderNode
drawing, since the distinction between tree root vs tree internal is
no longer important.
Change-Id: I2621eba0592c74d71f85a91a4ab3d0da2d7468d3
Diffstat (limited to 'libs/hwui/DisplayListOp.h')
-rw-r--r-- | libs/hwui/DisplayListOp.h | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/libs/hwui/DisplayListOp.h b/libs/hwui/DisplayListOp.h index 233f3f0..4dbebc5 100644 --- a/libs/hwui/DisplayListOp.h +++ b/libs/hwui/DisplayListOp.h @@ -1475,19 +1475,19 @@ public: virtual void defer(DeferStateStruct& deferStruct, int saveCount, int level, bool useQuickReject) { if (mDisplayList && mDisplayList->isRenderable() && !mSkipInOrderDraw) { - mDisplayList->deferNodeInParent(deferStruct, level + 1); + mDisplayList->defer(deferStruct, level + 1); } } virtual void replay(ReplayStateStruct& replayStruct, int saveCount, int level, bool useQuickReject) { if (mDisplayList && mDisplayList->isRenderable() && !mSkipInOrderDraw) { - mDisplayList->replayNodeInParent(replayStruct, level + 1); + mDisplayList->replay(replayStruct, level + 1); } } - // NOT USED since replay() is overridden virtual status_t applyDraw(OpenGLRenderer& renderer, Rect& dirty) { - return DrawGlInfo::kStatusDone; + LOG_ALWAYS_FATAL("should not be called, because replay() is overridden"); + return 0; } virtual void output(int level, uint32_t logFlags) const { |