summaryrefslogtreecommitdiff
path: root/libs/hwui/OpenGLRenderer.cpp
diff options
context:
space:
mode:
author John Reck <jreck@google.com> 2013-09-10 21:03:48 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2013-09-10 21:03:48 +0000
commit874ae2adf8c24c4b9d68f781239a95ad047e212a (patch)
treeb29d2b31bd84c38d9c643e67bc0327d01d820ab1 /libs/hwui/OpenGLRenderer.cpp
parent895a43751fcf4f33e5437963d75d05c2cd754520 (diff)
parent25d2f7bc1ff9b475eff75bfff647466e91dbacb2 (diff)
Merge "Fix scissor for functor invocation" into klp-dev
Diffstat (limited to 'libs/hwui/OpenGLRenderer.cpp')
-rw-r--r--libs/hwui/OpenGLRenderer.cpp6
1 files changed, 4 insertions, 2 deletions
diff --git a/libs/hwui/OpenGLRenderer.cpp b/libs/hwui/OpenGLRenderer.cpp
index 238d9a4955c6..2066f697dca8 100644
--- a/libs/hwui/OpenGLRenderer.cpp
+++ b/libs/hwui/OpenGLRenderer.cpp
@@ -471,12 +471,14 @@ status_t OpenGLRenderer::callDrawGLFunction(Functor* functor, Rect& dirty) {
info.height = getSnapshot()->height;
getSnapshot()->transform->copyTo(&info.transform[0]);
+ bool dirtyClip = mDirtyClip;
// setup GL state for functor
if (mDirtyClip) {
- setScissorFromClip();
setStencilFromClip(); // can issue draws, so must precede enableScissor()/interrupt()
}
- mCaches.enableScissor();
+ if (mCaches.enableScissor() || dirtyClip) {
+ setScissorFromClip();
+ }
interrupt();
// call functor immediately after GL state setup