summaryrefslogtreecommitdiffstats
path: root/Source/WebCore/platform/graphics/android/layers
diff options
context:
space:
mode:
authorNicolas Roard <nicolasroard@google.com>2012-05-17 17:32:25 -0700
committerNicolas Roard <nicolasroard@google.com>2012-05-17 18:01:19 -0700
commit377dc9f6b46a2ac0f968d9ee8d3c7916f3bf6904 (patch)
tree518fb21355b3530d6cdd18e3c6303348ee5501c0 /Source/WebCore/platform/graphics/android/layers
parent37df6b06a8481e3608cff1718038d353a8733d6c (diff)
downloadexternal_webkit-377dc9f6b46a2ac0f968d9ee8d3c7916f3bf6904.zip
external_webkit-377dc9f6b46a2ac0f968d9ee8d3c7916f3bf6904.tar.gz
external_webkit-377dc9f6b46a2ac0f968d9ee8d3c7916f3bf6904.tar.bz2
Fix invalidations sent to framework
bug:6479200 bug:6323847 bug:4124445 Change-Id: I1a4058ba6c69d3e285b6274d99a6eafcbf1cdc6f
Diffstat (limited to 'Source/WebCore/platform/graphics/android/layers')
-rw-r--r--Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp11
1 files changed, 7 insertions, 4 deletions
diff --git a/Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp b/Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp
index 7a25e7f..95e6825 100644
--- a/Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp
+++ b/Source/WebCore/platform/graphics/android/layers/LayerAndroid.cpp
@@ -273,6 +273,11 @@ void LayerAndroid::initAnimations() {
void LayerAndroid::addDirtyArea()
{
+ if (m_drawTransform.hasPerspective()) {
+ state()->doFrameworkFullInval();
+ return;
+ }
+
IntSize layerSize(getSize().width(), getSize().height());
FloatRect area =
@@ -816,12 +821,10 @@ bool LayerAndroid::drawGL(bool layerTilesDisabled)
bool askScreenUpdate = false;
m_atomicSync.lock();
- if (m_hasRunningAnimations || m_drawTransform.hasPerspective()) {
+ if (m_hasRunningAnimations)
askScreenUpdate = true;
- addDirtyArea();
- }
-
m_atomicSync.unlock();
+
return askScreenUpdate;
}