From 758724fd09a1599f2c55130f81953cfa6c17c300 Mon Sep 17 00:00:00 2001 From: Romain Guy Date: Wed, 27 Feb 2013 11:53:12 -0800 Subject: Don't increment the paint's generation ID when drawing bitmaps When the renderer draws a bitmap as part of a display list with an alpha < 1.0f, the paint is temporarily modified to alter the opacity of the bitmap. This has the side effect of increasing the paint's generation ID counter which can break paint caching. Change-Id: I5055d059ad1639829fa50af3d946e296c4dab877 --- libs/hwui/OpenGLRenderer.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'libs/hwui/OpenGLRenderer.cpp') diff --git a/libs/hwui/OpenGLRenderer.cpp b/libs/hwui/OpenGLRenderer.cpp index 34d1c983f87d..9df0c5852189 100644 --- a/libs/hwui/OpenGLRenderer.cpp +++ b/libs/hwui/OpenGLRenderer.cpp @@ -2942,8 +2942,14 @@ void OpenGLRenderer::setupPaintFilter(int clearBits, int setBits) { mDrawModifiers.mPaintFilterSetBits = setBits & SkPaint::kAllFlags; } -SkPaint* OpenGLRenderer::filterPaint(SkPaint* paint) { - if (CC_LIKELY(!mDrawModifiers.mHasDrawFilter || !paint)) return paint; +SkPaint* OpenGLRenderer::filterPaint(SkPaint* paint, bool alwaysCopy) { + if (CC_LIKELY(!mDrawModifiers.mHasDrawFilter || !paint)) { + if (CC_UNLIKELY(alwaysCopy)) { + mFilteredPaint = *paint; + return &mFilteredPaint; + } + return paint; + } uint32_t flags = paint->getFlags(); -- cgit v1.2.3-59-g8ed1b