Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CHROME_BROWSER_UI_EXCLUSIVE_ACCESS_FULLSCREEN_CONTROLLER_H_ | 5 #ifndef CHROME_BROWSER_UI_EXCLUSIVE_ACCESS_FULLSCREEN_CONTROLLER_H_ |
| 6 #define CHROME_BROWSER_UI_EXCLUSIVE_ACCESS_FULLSCREEN_CONTROLLER_H_ | 6 #define CHROME_BROWSER_UI_EXCLUSIVE_ACCESS_FULLSCREEN_CONTROLLER_H_ |
| 7 | 7 |
| 8 #include <set> | 8 #include <set> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| 11 #include "base/memory/weak_ptr.h" | 11 #include "base/memory/weak_ptr.h" |
| 12 #include "chrome/browser/ui/exclusive_access/exclusive_access_bubble_type.h" | 12 #include "chrome/browser/ui/exclusive_access/exclusive_access_controller_base.h" |
| 13 #include "components/content_settings/core/common/content_settings.h" | 13 #include "components/content_settings/core/common/content_settings.h" |
| 14 #include "content/public/browser/notification_observer.h" | 14 #include "content/public/browser/notification_observer.h" |
| 15 #include "content/public/browser/notification_registrar.h" | 15 #include "content/public/browser/notification_registrar.h" |
| 16 | 16 |
| 17 class Browser; | |
| 18 class BrowserWindow; | |
| 19 class GURL; | 17 class GURL; |
| 20 class Profile; | |
| 21 | 18 |
| 22 namespace content { | 19 namespace content { |
| 23 class WebContents; | 20 class WebContents; |
| 24 } | 21 } |
| 25 | 22 |
| 26 // There are two different kinds of fullscreen mode - "tab fullscreen" and | 23 // There are two different kinds of fullscreen mode - "tab fullscreen" and |
| 27 // "browser fullscreen". "Tab fullscreen" refers to a renderer-initiated | 24 // "browser fullscreen". "Tab fullscreen" refers to a renderer-initiated |
| 28 // fullscreen mode (eg: from a Flash plugin or via the JS fullscreen API), | 25 // fullscreen mode (eg: from a Flash plugin or via the JS fullscreen API), |
| 29 // whereas "browser fullscreen" refers to the user putting the browser itself | 26 // whereas "browser fullscreen" refers to the user putting the browser itself |
| 30 // into fullscreen mode from the UI. The difference is that tab fullscreen has | 27 // into fullscreen mode from the UI. The difference is that tab fullscreen has |
| 31 // implications for how the contents of the tab render (eg: a video element may | 28 // implications for how the contents of the tab render (eg: a video element may |
| 32 // grow to consume the whole tab), whereas browser fullscreen mode doesn't. | 29 // grow to consume the whole tab), whereas browser fullscreen mode doesn't. |
| 33 // Therefore if a user forces an exit from tab fullscreen, we need to notify the | 30 // Therefore if a user forces an exit from tab fullscreen, we need to notify the |
| 34 // tab so it can stop rendering in its fullscreen mode. | 31 // tab so it can stop rendering in its fullscreen mode. |
| 35 // | 32 // |
| 36 // For Flash, FullscreenController will auto-accept all permission requests for | 33 // For Flash, FullscreenController will auto-accept all permission requests for |
| 37 // fullscreen and/or mouse lock, since the assumption is that the plugin handles | 34 // fullscreen, since the assumption is that the plugin handles this for us. |
| 38 // this for us. | |
| 39 // | 35 // |
| 40 // FullscreenWithinTab Note: | 36 // FullscreenWithinTab Note: |
| 41 // All fullscreen widgets are displayed within the tab contents area, and | 37 // All fullscreen widgets are displayed within the tab contents area, and |
| 42 // FullscreenController will expand the browser window so that the tab contents | 38 // FullscreenController will expand the browser window so that the tab contents |
| 43 // area fills the entire screen. However, special behavior applies when a tab is | 39 // area fills the entire screen. However, special behavior applies when a tab is |
| 44 // being screen-captured. First, the browser window will not be | 40 // being screen-captured. First, the browser window will not be |
| 45 // fullscreened. This allows the user to retain control of their desktop to work | 41 // fullscreened. This allows the user to retain control of their desktop to work |
| 46 // in other browser tabs or applications while the fullscreen view is displayed | 42 // in other browser tabs or applications while the fullscreen view is displayed |
| 47 // on a remote screen. Second, FullscreenController will auto-resize fullscreen | 43 // on a remote screen. Second, FullscreenController will auto-resize fullscreen |
| 48 // widgets to that of the capture video resolution when they are hidden (e.g., | 44 // widgets to that of the capture video resolution when they are hidden (e.g., |
| 49 // when a user has switched to another tab). This is both a performance and | 45 // when a user has switched to another tab). This is both a performance and |
| 50 // quality improvement since scaling and letterboxing steps can be skipped in | 46 // quality improvement since scaling and letterboxing steps can be skipped in |
| 51 // the capture pipeline. | 47 // the capture pipeline. |
| 52 | 48 |
| 53 // This class implements fullscreen and mouselock behaviour. | 49 // This class implements fullscreen behaviour. |
| 54 class FullscreenController : public content::NotificationObserver { | 50 class FullscreenController : public ExclusiveAccessControllerBase { |
| 55 public: | 51 public: |
| 56 explicit FullscreenController(Browser* browser); | 52 explicit FullscreenController(ExclusiveAccessManager* manager, |
|
miu
2015/01/16 22:17:39
Don't need explicit keyword anymore.
Sriram
2015/01/21 01:38:57
Done.
| |
| 53 Browser* browser); | |
| 57 ~FullscreenController() override; | 54 ~FullscreenController() override; |
| 58 | 55 |
| 59 // Browser/User Fullscreen /////////////////////////////////////////////////// | 56 // Browser/User Fullscreen /////////////////////////////////////////////////// |
| 60 | 57 |
| 61 // Returns true if the window is currently fullscreen and was initially | 58 // Returns true if the window is currently fullscreen and was initially |
| 62 // transitioned to fullscreen by a browser (i.e., not tab-initiated) mode | 59 // transitioned to fullscreen by a browser (i.e., not tab-initiated) mode |
| 63 // transition. | 60 // transition. |
| 64 bool IsFullscreenForBrowser() const; | 61 bool IsFullscreenForBrowser() const; |
| 65 | 62 |
| 63 bool IsPrivilegedFullscreenForTab() const; | |
|
miu
2015/01/16 22:17:39
Needs comment. Might be worth mentioning this is
Sriram
2015/01/21 01:38:57
Done.
| |
| 64 | |
| 66 void ToggleBrowserFullscreenMode(); | 65 void ToggleBrowserFullscreenMode(); |
| 67 | 66 |
| 68 // Fullscreen mode with tab strip and toolbar shown. | 67 // Fullscreen mode with tab strip and toolbar shown. |
| 69 // Currently only supported on Mac. | 68 // Currently only supported on Mac. |
| 70 void ToggleBrowserFullscreenWithToolbar(); | 69 void ToggleBrowserFullscreenWithToolbar(); |
| 71 | 70 |
| 72 // Extension API implementation uses this method to toggle fullscreen mode. | 71 // Extension API implementation uses this method to toggle fullscreen mode. |
| 73 // The extension's name is displayed in the full screen bubble UI to attribute | 72 // The extension's name is displayed in the full screen bubble UI to attribute |
| 74 // the cause of the full screen state change. | 73 // the cause of the full screen state change. |
| 75 void ToggleBrowserFullscreenModeWithExtension(const GURL& extension_url); | 74 void ToggleBrowserFullscreenModeWithExtension(const GURL& extension_url); |
| 76 | 75 |
| 77 // Tab/HTML/Flash Fullscreen ///////////////////////////////////////////////// | 76 // Tab/HTML/Flash Fullscreen ///////////////////////////////////////////////// |
| 78 | 77 |
| 79 // Returns true if the browser window has/will fullscreen because of | 78 // Returns true if the browser window has/will fullscreen because of |
| 80 // tab-initiated fullscreen. The window may still be transitioning, and | 79 // tab-initiated fullscreen. The window may still be transitioning, and |
| 81 // BrowserWindow::IsFullscreen() may still return false. | 80 // BrowserWindow::IsFullscreen() may still return false. |
| 82 bool IsWindowFullscreenForTabOrPending() const; | 81 bool IsWindowFullscreenForTabOrPending() const; |
| 83 | 82 |
| 83 // Returns true if the browser window is fullscreen because of extension | |
| 84 // initiated fullscreen. | |
| 85 bool IsExtensionFullscreenOrPending() const; | |
| 86 | |
| 87 // Returns true if controller has entered fullscrene mode. | |
|
miu
2015/01/16 22:17:39
/fullscrene/fullscreen/
Sriram
2015/01/21 01:38:57
Done.
| |
| 88 bool IsControllerInitiatedFullscreen() const; | |
| 89 | |
| 90 // Returns true if the user has accepted fullscreen. | |
| 91 bool IsUserAcceptedFullscreen() const; | |
| 92 | |
| 84 // Returns true if the tab is/will be in fullscreen mode. Note: This does NOT | 93 // Returns true if the tab is/will be in fullscreen mode. Note: This does NOT |
| 85 // indicate whether the browser window is/will be fullscreened as well. See | 94 // indicate whether the browser window is/will be fullscreened as well. See |
| 86 // 'FullscreenWithinTab Note'. | 95 // 'FullscreenWithinTab Note'. |
| 87 bool IsFullscreenForTabOrPending( | 96 bool IsFullscreenForTabOrPending( |
| 88 const content::WebContents* web_contents) const; | 97 const content::WebContents* web_contents) const; |
| 89 | 98 |
| 90 // True if fullscreen was entered because of tab fullscreen (was not | 99 // True if fullscreen was entered because of tab fullscreen (was not |
| 91 // previously in user-initiated fullscreen). | 100 // previously in user-initiated fullscreen). |
| 92 bool IsFullscreenCausedByTab() const; | 101 bool IsFullscreenCausedByTab() const; |
| 93 | 102 |
| 94 // Enter or leave tab-initiated fullscreen mode. FullscreenController will | 103 // Enter or leave tab-initiated fullscreen mode. FullscreenController will |
| 95 // decide whether to also fullscreen the browser window. See | 104 // decide whether to also fullscreen the browser window. See |
| 96 // 'FullscreenWithinTab Note'. | 105 // 'FullscreenWithinTab Note'. |
| 97 void ToggleFullscreenModeForTab(content::WebContents* web_contents, | 106 void ToggleFullscreenModeForTab(content::WebContents* web_contents, |
| 98 bool enter_fullscreen); | 107 bool enter_fullscreen); |
| 99 | 108 |
| 100 // Platform Fullscreen /////////////////////////////////////////////////////// | 109 // Platform Fullscreen /////////////////////////////////////////////////////// |
| 101 | 110 |
| 102 // Returns whether we are currently in a Metro snap view. | 111 // Returns whether we are currently in a Metro snap view. |
| 103 bool IsInMetroSnapMode(); | 112 bool IsInMetroSnapMode(); |
| 104 | 113 |
| 105 #if defined(OS_WIN) | 114 #if defined(OS_WIN) |
| 106 // API that puts the window into a mode suitable for rendering when Chrome | 115 // API that puts the window into a mode suitable for rendering when Chrome |
| 107 // is rendered in a 20% screen-width Metro snap view on Windows 8. | 116 // is rendered in a 20% screen-width Metro snap view on Windows 8. |
| 108 void SetMetroSnapMode(bool enable); | 117 void SetMetroSnapMode(bool enable); |
| 109 #endif | 118 #endif |
| 110 | 119 |
| 111 // Mouse Lock //////////////////////////////////////////////////////////////// | 120 // Overrde from ExclusiveAccessControllerBase. |
| 121 void OnTabDetachedFromView(content::WebContents* web_contents) override; | |
| 122 void OnTabClosing(content::WebContents* web_contents) override; | |
| 123 bool HandleUserPressedEscape() override; | |
| 112 | 124 |
| 113 bool IsMouseLockRequested() const; | 125 void ExitExclusiveAccessToPreviousState() override; |
| 114 bool IsMouseLocked() const; | 126 bool OnAcceptExclusiveAccessPermission() override; |
| 115 | 127 bool OnDenyExclusiveAccessPermission() override; |
| 116 void RequestToLockMouse(content::WebContents* web_contents, | 128 GURL GetURLForExclusiveAccessBubble() const override; |
| 117 bool user_gesture, | 129 void ExitExclusiveAccessIfNecessary() override; |
| 118 bool last_unlocked_by_target); | |
| 119 | |
| 120 // Callbacks ///////////////////////////////////////////////////////////////// | 130 // Callbacks ///////////////////////////////////////////////////////////////// |
| 121 | 131 |
| 122 // Called by Browser::TabDeactivated. | |
| 123 void OnTabDeactivated(content::WebContents* web_contents); | |
| 124 | |
| 125 // Called by Browser::ActiveTabChanged. | |
| 126 void OnTabDetachedFromView(content::WebContents* web_contents); | |
| 127 | |
| 128 // Called by Browser::TabClosingAt. | |
| 129 void OnTabClosing(content::WebContents* web_contents); | |
| 130 | |
| 131 // Called by Browser::WindowFullscreenStateChanged. | 132 // Called by Browser::WindowFullscreenStateChanged. |
| 132 void WindowFullscreenStateChanged(); | 133 void WindowFullscreenStateChanged(); |
| 133 | 134 |
| 134 // Called by Browser::PreHandleKeyboardEvent. | |
| 135 bool HandleUserPressedEscape(); | |
| 136 | |
| 137 // Called by platform FullscreenExitBubble. | |
| 138 void ExitTabOrBrowserFullscreenToPreviousState(); | |
| 139 void OnAcceptFullscreenPermission(); | |
| 140 void OnDenyFullscreenPermission(); | |
| 141 | |
| 142 // Called by Browser::LostMouseLock. | |
| 143 void LostMouseLock(); | |
| 144 | |
| 145 // content::NotificationObserver: | |
| 146 void Observe(int type, | |
| 147 const content::NotificationSource& source, | |
| 148 const content::NotificationDetails& details) override; | |
| 149 | |
| 150 // Bubble Content //////////////////////////////////////////////////////////// | |
| 151 | |
| 152 GURL GetFullscreenExitBubbleURL() const; | |
| 153 ExclusiveAccessBubbleType GetExclusiveAccessBubbleType() const; | |
| 154 | |
| 155 private: | 135 private: |
| 156 friend class FullscreenControllerTest; | 136 friend class FullscreenControllerTest; |
| 157 | 137 |
| 158 enum MouseLockState { | |
| 159 MOUSELOCK_NOT_REQUESTED, | |
| 160 // The page requests to lock the mouse and the user hasn't responded to the | |
| 161 // request. | |
| 162 MOUSELOCK_REQUESTED, | |
| 163 // Mouse lock has been allowed by the user. | |
| 164 MOUSELOCK_ACCEPTED, | |
| 165 // Mouse lock has been silently accepted, no notification to user. | |
| 166 MOUSELOCK_ACCEPTED_SILENTLY | |
| 167 }; | |
| 168 | |
| 169 enum FullscreenInternalOption { | 138 enum FullscreenInternalOption { |
| 170 BROWSER, | 139 BROWSER, |
| 171 BROWSER_WITH_TOOLBAR, | 140 BROWSER_WITH_TOOLBAR, |
| 172 TAB | 141 TAB |
| 173 }; | 142 }; |
| 174 | 143 |
| 175 void UpdateNotificationRegistrations(); | |
| 176 | |
| 177 // Posts a task to call NotifyFullscreenChange. | 144 // Posts a task to call NotifyFullscreenChange. |
| 178 void PostFullscreenChangeNotification(bool is_fullscreen); | 145 void PostFullscreenChangeNotification(bool is_fullscreen); |
| 179 // Sends a NOTIFICATION_FULLSCREEN_CHANGED notification. | 146 // Sends a NOTIFICATION_FULLSCREEN_CHANGED notification. |
| 180 void NotifyFullscreenChange(bool is_fullscreen); | 147 void NotifyFullscreenChange(bool is_fullscreen); |
| 181 // Notifies the tab that it has been forced out of fullscreen and mouse lock | 148 |
| 182 // mode if necessary. | 149 // Notifies the tab that it has been forced out of fullscreen mode if |
| 183 void NotifyTabOfExitIfNecessary(); | 150 // necessary. |
| 184 void NotifyMouseLockChange(); | 151 void NotifyTabOfExclusiveAccessChange() override; |
| 185 | 152 |
| 186 void ToggleFullscreenModeInternal(FullscreenInternalOption option); | 153 void ToggleFullscreenModeInternal(FullscreenInternalOption option); |
| 187 void EnterFullscreenModeInternal(FullscreenInternalOption option); | 154 void EnterFullscreenModeInternal(FullscreenInternalOption option); |
| 188 void ExitFullscreenModeInternal(); | 155 void ExitFullscreenModeInternal(); |
| 189 void SetFullscreenedTab(content::WebContents* tab); | |
| 190 void SetMouseLockTab(content::WebContents* tab); | |
| 191 | |
| 192 // Make the current tab exit fullscreen mode or mouse lock if it is in it. | |
| 193 void ExitTabFullscreenOrMouseLockIfNecessary(); | |
| 194 void UpdateFullscreenExitBubbleContent(); | |
| 195 | 156 |
| 196 ContentSetting GetFullscreenSetting(const GURL& url) const; | 157 ContentSetting GetFullscreenSetting(const GURL& url) const; |
| 197 ContentSetting GetMouseLockSetting(const GURL& url) const; | |
| 198 | 158 |
| 199 bool IsPrivilegedFullscreenForTab() const; | |
| 200 void SetPrivilegedFullscreenForTesting(bool is_privileged); | 159 void SetPrivilegedFullscreenForTesting(bool is_privileged); |
| 201 // Returns true if |web_contents| was toggled into/out of fullscreen mode as a | 160 // Returns true if |web_contents| was toggled into/out of fullscreen mode as a |
| 202 // screen-captured tab. See 'FullscreenWithinTab Note'. | 161 // screen-captured tab. See 'FullscreenWithinTab Note'. |
| 203 bool MaybeToggleFullscreenForCapturedTab(content::WebContents* web_contents, | 162 bool MaybeToggleFullscreenForCapturedTab(content::WebContents* web_contents, |
| 204 bool enter_fullscreen); | 163 bool enter_fullscreen); |
| 205 // Returns true if |web_contents| is in fullscreen mode as a screen-captured | 164 // Returns true if |web_contents| is in fullscreen mode as a screen-captured |
| 206 // tab. See 'FullscreenWithinTab Note'. | 165 // tab. See 'FullscreenWithinTab Note'. |
| 207 bool IsFullscreenForCapturedTab(const content::WebContents* web_contents) | 166 bool IsFullscreenForCapturedTab(const content::WebContents* web_contents) |
| 208 const; | 167 const; |
| 209 void UnlockMouse(); | 168 void UnlockMouse(); |
|
miu
2015/01/16 22:17:39
Should UnlockMouse() be removed?
Sriram
2015/01/21 01:38:57
Done.
| |
| 210 | 169 |
| 211 Browser* const browser_; | |
| 212 BrowserWindow* const window_; | |
| 213 Profile* const profile_; | |
| 214 | |
| 215 // If there is currently a tab in fullscreen mode (entered via | |
| 216 // webkitRequestFullScreen), this is its WebContents. | |
| 217 // Assign using SetFullscreenedTab(). | |
| 218 content::WebContents* fullscreened_tab_; | |
| 219 | |
| 220 // The URL of the extension which trigerred "browser fullscreen" mode. | 170 // The URL of the extension which trigerred "browser fullscreen" mode. |
| 221 GURL extension_caused_fullscreen_; | 171 GURL extension_caused_fullscreen_; |
| 222 | 172 |
| 223 enum PriorFullscreenState { | 173 enum PriorFullscreenState { |
| 224 STATE_INVALID, | 174 STATE_INVALID, |
| 225 STATE_NORMAL, | 175 STATE_NORMAL, |
| 226 STATE_BROWSER_FULLSCREEN_NO_TOOLBAR, | 176 STATE_BROWSER_FULLSCREEN_NO_TOOLBAR, |
| 227 STATE_BROWSER_FULLSCREEN_WITH_TOOLBAR, | 177 STATE_BROWSER_FULLSCREEN_WITH_TOOLBAR, |
| 228 }; | 178 }; |
| 229 // The state before entering tab fullscreen mode via webkitRequestFullScreen. | 179 // The state before entering tab fullscreen mode via webkitRequestFullScreen. |
| 230 // When not in tab fullscreen, it is STATE_INVALID. | 180 // When not in tab fullscreen, it is STATE_INVALID. |
| 231 PriorFullscreenState state_prior_to_tab_fullscreen_; | 181 PriorFullscreenState state_prior_to_tab_fullscreen_; |
| 232 // True if tab fullscreen has been allowed, either by settings or by user | 182 // True if tab fullscreen has been allowed, either by settings or by user |
| 233 // clicking the allow button on the fullscreen infobar. | 183 // clicking the allow button on the fullscreen infobar. |
| 234 bool tab_fullscreen_accepted_; | 184 bool tab_fullscreen_accepted_; |
| 235 | 185 |
| 236 // True if this controller has toggled into tab OR browser fullscreen. | 186 // True if this controller has toggled into tab OR browser fullscreen. |
| 237 bool toggled_into_fullscreen_; | 187 bool toggled_into_fullscreen_; |
| 238 | 188 |
| 239 // WebContents for current tab requesting or currently in mouse lock. | |
| 240 // Assign using SetMouseLockTab(). | |
| 241 content::WebContents* mouse_lock_tab_; | |
| 242 | |
| 243 MouseLockState mouse_lock_state_; | |
| 244 | |
| 245 content::NotificationRegistrar registrar_; | |
| 246 | |
| 247 // Used to verify that calls we expect to reenter by calling | 189 // Used to verify that calls we expect to reenter by calling |
| 248 // WindowFullscreenStateChanged do so. | 190 // WindowFullscreenStateChanged do so. |
| 249 bool reentrant_window_state_change_call_check_; | 191 bool reentrant_window_state_change_call_check_; |
| 250 | 192 |
| 251 // Used in testing to confirm proper behavior for specific, privileged | 193 // Used in testing to confirm proper behavior for specific, privileged |
| 252 // fullscreen cases. | 194 // fullscreen cases. |
| 253 bool is_privileged_fullscreen_for_testing_; | 195 bool is_privileged_fullscreen_for_testing_; |
| 254 | 196 |
| 255 base::WeakPtrFactory<FullscreenController> ptr_factory_; | 197 base::WeakPtrFactory<FullscreenController> ptr_factory_; |
| 256 | 198 |
| 257 DISALLOW_COPY_AND_ASSIGN(FullscreenController); | 199 DISALLOW_COPY_AND_ASSIGN(FullscreenController); |
| 258 }; | 200 }; |
| 259 | 201 |
| 260 #endif // CHROME_BROWSER_UI_EXCLUSIVE_ACCESS_FULLSCREEN_CONTROLLER_H_ | 202 #endif // CHROME_BROWSER_UI_EXCLUSIVE_ACCESS_FULLSCREEN_CONTROLLER_H_ |
| OLD | NEW |