summaryrefslogtreecommitdiffstats
path: root/Source/WebCore
diff options
context:
space:
mode:
authorTeng-Hui Zhu <ztenghui@google.com>2011-09-12 11:20:44 -0700
committerTeng-Hui Zhu <ztenghui@google.com>2011-09-12 13:20:05 -0700
commita6a655013a05dce8dd34c69e4bba05d49f5e9c4d (patch)
treeed6010fc9f3a8e624ae47521c05bb55002457a2e /Source/WebCore
parent13d9e99a89d771d44695e9ddbc28ef0811588076 (diff)
downloadexternal_webkit-a6a655013a05dce8dd34c69e4bba05d49f5e9c4d.zip
external_webkit-a6a655013a05dce8dd34c69e4bba05d49f5e9c4d.tar.gz
external_webkit-a6a655013a05dce8dd34c69e4bba05d49f5e9c4d.tar.bz2
Fix the poster issue and full screen behavior html5 video
This is related to the change in https://bugs.webkit.org/show_bug.cgi?id=49481, and it seems there is some following up discussion in this area. We will just follow what we did from Honeycomb and work around issues for now. bug:4523481 Change-Id: I3c2225afb078c24db423119a235266f222055431
Diffstat (limited to 'Source/WebCore')
-rw-r--r--Source/WebCore/dom/Document.cpp18
1 files changed, 16 insertions, 2 deletions
diff --git a/Source/WebCore/dom/Document.cpp b/Source/WebCore/dom/Document.cpp
index 638b4ab..c8bf374 100644
--- a/Source/WebCore/dom/Document.cpp
+++ b/Source/WebCore/dom/Document.cpp
@@ -4870,6 +4870,11 @@ void Document::webkitCancelFullScreen()
return;
page()->chrome()->client()->exitFullScreenForElement(m_fullScreenElement.get());
+#if PLATFORM(ANDROID)
+ // The next time we try to enter full screen, we need this change to know
+ // we are not in full screen any more.
+ m_fullScreenElement = 0;
+#endif
}
void Document::webkitWillEnterFullScreenForElement(Element* element)
@@ -4878,12 +4883,21 @@ void Document::webkitWillEnterFullScreenForElement(Element* element)
ASSERT(page() && page()->settings()->fullScreenEnabled());
m_fullScreenElement = element;
-
+
+#if PLATFORM(ANDROID)
+ // Our approach on Poster handling is android specific: we are passing the
+ // poster from java side to native and we can't keep the content if the
+ // video element is detached and its RenderLayer object is deleted.
+ if(!(m_fullScreenElement->hasTagName(HTMLNames::videoTag))) {
+#endif
if (m_fullScreenElement != documentElement())
m_fullScreenElement->detach();
recalcStyle(Force);
-
+#if PLATFORM(ANDROID)
+ }
+#endif
+
if (m_fullScreenRenderer) {
m_fullScreenRenderer->setAnimating(true);
#if USE(ACCELERATED_COMPOSITING)