OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 19 matching lines...) Expand all Loading... |
30 | 30 |
31 #include "web/FullscreenController.h" | 31 #include "web/FullscreenController.h" |
32 | 32 |
33 #include "core/dom/Document.h" | 33 #include "core/dom/Document.h" |
34 #include "core/dom/Fullscreen.h" | 34 #include "core/dom/Fullscreen.h" |
35 #include "core/frame/FrameView.h" | 35 #include "core/frame/FrameView.h" |
36 #include "core/frame/LocalFrame.h" | 36 #include "core/frame/LocalFrame.h" |
37 #include "core/frame/PageScaleConstraintsSet.h" | 37 #include "core/frame/PageScaleConstraintsSet.h" |
38 #include "core/html/HTMLMediaElement.h" | 38 #include "core/html/HTMLMediaElement.h" |
39 #include "core/html/HTMLVideoElement.h" | 39 #include "core/html/HTMLVideoElement.h" |
| 40 #include "core/layout/LayoutFullScreen.h" |
40 #include "platform/RuntimeEnabledFeatures.h" | 41 #include "platform/RuntimeEnabledFeatures.h" |
41 #include "public/platform/WebLayerTreeView.h" | 42 #include "public/platform/WebLayerTreeView.h" |
42 #include "public/web/WebFrameClient.h" | 43 #include "public/web/WebFrameClient.h" |
43 #include "web/WebLocalFrameImpl.h" | 44 #include "web/WebLocalFrameImpl.h" |
44 #include "web/WebSettingsImpl.h" | 45 #include "web/WebSettingsImpl.h" |
45 #include "web/WebViewImpl.h" | 46 #include "web/WebViewImpl.h" |
46 | 47 |
47 namespace blink { | 48 namespace blink { |
48 | 49 |
49 FullscreenController* FullscreenController::create(WebViewImpl* webViewImpl) | 50 FullscreenController* FullscreenController::create(WebViewImpl* webViewImpl) |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
123 } | 124 } |
124 } | 125 } |
125 } | 126 } |
126 | 127 |
127 m_haveEnteredFullscreen = false; | 128 m_haveEnteredFullscreen = false; |
128 m_fullScreenFrame.clear(); | 129 m_fullScreenFrame.clear(); |
129 } | 130 } |
130 | 131 |
131 void FullscreenController::enterFullScreenForElement(Element* element) | 132 void FullscreenController::enterFullScreenForElement(Element* element) |
132 { | 133 { |
133 // TODO(dsinclair): This should not be needed because we addToTopLayer | |
134 // in Fullscreen::pushFullscreenElementStack but, the WebView code doesn't | |
135 // call Fullscreen::requestFullscreen() and, instead, just enters and | |
136 // exists itself. This should be unified so there is one way to go | |
137 // fullscreen. crbug.com/538158 | |
138 element->document().addToTopLayer(element); | |
139 | |
140 // We are already transitioning to fullscreen for a different element. | 134 // We are already transitioning to fullscreen for a different element. |
141 if (m_provisionalFullScreenElement) { | 135 if (m_provisionalFullScreenElement) { |
142 m_provisionalFullScreenElement = element; | 136 m_provisionalFullScreenElement = element; |
143 return; | 137 return; |
144 } | 138 } |
145 | 139 |
146 // We are already in fullscreen mode. | 140 // We are already in fullscreen mode. |
147 if (m_fullScreenFrame) { | 141 if (m_fullScreenFrame) { |
148 m_provisionalFullScreenElement = element; | 142 m_provisionalFullScreenElement = element; |
149 didEnterFullscreen(); | 143 didEnterFullscreen(); |
(...skipping 17 matching lines...) Expand all Loading... |
167 if (!Fullscreen::from(element->document()).forCrossProcessDescendant()) | 161 if (!Fullscreen::from(element->document()).forCrossProcessDescendant()) |
168 frame->client()->enterFullscreen(); | 162 frame->client()->enterFullscreen(); |
169 m_provisionalFullScreenElement = element; | 163 m_provisionalFullScreenElement = element; |
170 } | 164 } |
171 } | 165 } |
172 | 166 |
173 void FullscreenController::exitFullScreenForElement(Element* element) | 167 void FullscreenController::exitFullScreenForElement(Element* element) |
174 { | 168 { |
175 DCHECK(element); | 169 DCHECK(element); |
176 | 170 |
177 // TODO(dsinclair): This should not be needed because we addToTopLayer | |
178 // in Fullscreen::popFullscreenElementStack but, the WebView code doesn't | |
179 // call Fullscreen::requestFullscreen() and, instead, just enters and | |
180 // exists itself. This should be unified so there is one way to go | |
181 // fullscreen. crbug.com/538158 | |
182 element->document().removeFromTopLayer(element); | |
183 | |
184 // The client is exiting full screen, so don't send a notification. | 171 // The client is exiting full screen, so don't send a notification. |
185 if (m_isCancelingFullScreen) | 172 if (m_isCancelingFullScreen) |
186 return; | 173 return; |
187 | 174 |
188 WebLocalFrameImpl* frame = WebLocalFrameImpl::fromFrame(element->document().
frame()); | 175 WebLocalFrameImpl* frame = WebLocalFrameImpl::fromFrame(element->document().
frame()); |
189 if (frame && frame->client()) | 176 if (frame && frame->client()) |
190 frame->client()->exitFullscreen(); | 177 frame->client()->exitFullscreen(); |
191 } | 178 } |
192 | 179 |
193 void FullscreenController::updateSize() | 180 void FullscreenController::updateSize() |
194 { | 181 { |
195 if (!isFullscreen()) | 182 if (!isFullscreen()) |
196 return; | 183 return; |
197 | 184 |
198 updatePageScaleConstraints(false); | 185 updatePageScaleConstraints(false); |
199 | 186 |
200 Document* document = m_fullScreenFrame->document(); | 187 LayoutFullScreen* layoutObject = Fullscreen::from(*m_fullScreenFrame->docume
nt()).fullScreenLayoutObject(); |
201 if (Element* fullscreenElement = Fullscreen::currentFullScreenElementFrom(*d
ocument)) | 188 if (layoutObject) |
202 Fullscreen::from(fullscreenElement->document()).didUpdateSize(*fullscree
nElement); | 189 layoutObject->updateStyle(); |
203 } | 190 } |
204 | 191 |
205 void FullscreenController::didUpdateLayout() | 192 void FullscreenController::didUpdateLayout() |
206 { | 193 { |
207 if (!m_needsScrollAndScaleRestore) | 194 if (!m_needsScrollAndScaleRestore) |
208 return; | 195 return; |
209 | 196 |
210 // If we re-entered fullscreen before we could restore the scroll and scale | 197 // If we re-entered fullscreen before we could restore the scroll and scale |
211 // don't try restoring them yet. | 198 // don't try restoring them yet. |
212 if (isFullscreen()) | 199 if (isFullscreen()) |
(...skipping 28 matching lines...) Expand all Loading... |
241 m_webViewImpl->updateMainFrameLayoutSize(); | 228 m_webViewImpl->updateMainFrameLayoutSize(); |
242 } | 229 } |
243 | 230 |
244 DEFINE_TRACE(FullscreenController) | 231 DEFINE_TRACE(FullscreenController) |
245 { | 232 { |
246 visitor->trace(m_provisionalFullScreenElement); | 233 visitor->trace(m_provisionalFullScreenElement); |
247 visitor->trace(m_fullScreenFrame); | 234 visitor->trace(m_fullScreenFrame); |
248 } | 235 } |
249 | 236 |
250 } // namespace blink | 237 } // namespace blink |
OLD | NEW |