diff options
| author | 2013-09-10 14:05:32 -0700 | |
|---|---|---|
| committer | 2013-09-10 14:05:32 -0700 | |
| commit | 53760b4a97fb2f88e94da73d647ff80221b3c454 (patch) | |
| tree | 5c5bc6bec53735270df6984dd0fad8533e4f45d8 /libs/hwui/OpenGLRenderer.cpp | |
| parent | 19c727bbc6371924bfd2f85e804b5b6b093a8413 (diff) | |
| parent | 874ae2adf8c24c4b9d68f781239a95ad047e212a (diff) | |
am 874ae2ad: Merge "Fix scissor for functor invocation" into klp-dev
* commit '874ae2adf8c24c4b9d68f781239a95ad047e212a':
Fix scissor for functor invocation
Diffstat (limited to 'libs/hwui/OpenGLRenderer.cpp')
| -rw-r--r-- | libs/hwui/OpenGLRenderer.cpp | 6 |
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 |