summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Craik <ccraik@google.com>2012-08-16 16:44:40 -0700
committerChris Craik <ccraik@google.com>2012-08-16 16:44:40 -0700
commit78acc1eae6ab06bb0b79648eb24ce77a551e264a (patch)
treec64ea326f073763e6239d8c4ff7b463e361480b0
parentde7ee90281a581b2d1c1db13644b5a01e08bd150 (diff)
downloadexternal_webkit-78acc1eae6ab06bb0b79648eb24ce77a551e264a.zip
external_webkit-78acc1eae6ab06bb0b79648eb24ce77a551e264a.tar.gz
external_webkit-78acc1eae6ab06bb0b79648eb24ce77a551e264a.tar.bz2
Early return from layer painting when fully clipped
Fixes logspam due to merged layers unnecessarily painting when fully clipped. Change-Id: I0f2f1b851c9386dcebda58bf844fd68073338e1c
-rw-r--r--Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp15
1 files changed, 8 insertions, 7 deletions
diff --git a/Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp b/Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp
index 67d1259..84ce910 100644
--- a/Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp
+++ b/Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp
@@ -803,13 +803,14 @@ bool LayerAndroid::drawCanvas(SkCanvas* canvas, bool drawChildren, PaintStyle st
r.set(m_clippingRect.x(), m_clippingRect.y(),
m_clippingRect.x() + m_clippingRect.width(),
m_clippingRect.y() + m_clippingRect.height());
- canvas->clipRect(r);
- SkMatrix matrix;
- GLUtils::toSkMatrix(matrix, m_drawTransform);
- SkMatrix canvasMatrix = canvas->getTotalMatrix();
- matrix.postConcat(canvasMatrix);
- canvas->setMatrix(matrix);
- onDraw(canvas, m_drawOpacity, 0, style);
+ if (canvas->clipRect(r)) {
+ SkMatrix matrix;
+ GLUtils::toSkMatrix(matrix, m_drawTransform);
+ SkMatrix canvasMatrix = canvas->getTotalMatrix();
+ matrix.postConcat(canvasMatrix);
+ canvas->setMatrix(matrix);
+ onDraw(canvas, m_drawOpacity, 0, style);
+ }
}
if (!drawChildren)