Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(73)

Unified Diff: chrome/browser/ui/cocoa/presentation_mode_controller.h

Issue 7566016: Fullscreen support for Lion. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/cocoa/presentation_mode_controller.h
===================================================================
--- chrome/browser/ui/cocoa/presentation_mode_controller.h (revision 95287)
+++ chrome/browser/ui/cocoa/presentation_mode_controller.h (working copy)
@@ -1,9 +1,9 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef CHROME_BROWSER_UI_COCOA_FULLSCREEN_CONTROLLER_H_
-#define CHROME_BROWSER_UI_COCOA_FULLSCREEN_CONTROLLER_H_
+#ifndef CHROME_BROWSER_UI_COCOA_PRESENTATION_MODE_CONTROLLER_H_
+#define CHROME_BROWSER_UI_COCOA_PRESENTATION_MODE_CONTROLLER_H_
#pragma once
#import <Cocoa/Cocoa.h>
@@ -15,11 +15,11 @@
@class BrowserWindowController;
@class DropdownAnimation;
-// Provides a controller to manage fullscreen mode for a single browser window.
-// This class handles running animations, showing and hiding the floating
-// dropdown bar, and managing the tracking area associated with the dropdown.
-// This class does not directly manage any views -- the BrowserWindowController
-// is responsible for positioning and z-ordering views.
+// Provides a controller to manage presentation mode for a single browser
+// window. This class handles running animations, showing and hiding the
+// floating dropdown bar, and managing the tracking area associated with the
+// dropdown. This class does not directly manage any views -- the
+// BrowserWindowController is responsible for positioning and z-ordering views.
//
// Tracking areas are disabled while animations are running. If
// |overlayFrameChanged:| is called while an animation is running, the
@@ -27,23 +27,26 @@
// when the animation finishes. This is largely done for ease of
// implementation; it is easier to check the mouse location at each animation
// step than it is to manage a constantly-changing tracking area.
-@interface FullscreenController : NSObject<NSAnimationDelegate> {
+@interface PresentationModeController : NSObject<NSAnimationDelegate> {
@private
// Our parent controller.
BrowserWindowController* browserController_; // weak
- // The content view for the fullscreen window. This is nil when not in
- // fullscreen mode.
+ // The content view for the window. This is nil when not in presentation
+ // mode.
NSView* contentView_; // weak
- // Whether or not we are in fullscreen mode.
- BOOL isFullscreen_;
+ // YES while this controller is in the process of entering presentation mode.
+ BOOL enteringPresentationMode_;
+ // Whether or not we are in presentation mode.
+ BOOL inPresentationMode_;
+
// The tracking area associated with the floating dropdown bar. This tracking
// area is attached to |contentView_|, because when the dropdown is completely
// hidden, we still need to keep a 1px tall tracking area visible. Attaching
// to the content view allows us to do this. |trackingArea_| can be nil if
- // not in fullscreen mode or during animations.
+ // not in presentation mode or during animations.
scoped_nsobject<NSTrackingArea> trackingArea_;
// Pointer to the currently running animation. Is nil if no animation is
@@ -60,38 +63,38 @@
// completes.
NSRect trackingAreaBounds_;
- // Tracks the currently requested fullscreen mode. This should be
- // |kFullScreenModeNormal| when the window is not main or not fullscreen,
- // |kFullScreenModeHideAll| while the overlay is hidden, and
- // |kFullScreenModeHideDock| while the overlay is shown. If the window is not
- // on the primary screen, this should always be |kFullScreenModeNormal|. This
- // value can get out of sync with the correct state if we miss a notification
- // (which can happen when a fullscreen window is closed). Used to track the
- // current state and make sure we properly restore the menu bar when this
- // controller is destroyed.
- base::mac::FullScreenMode currentFullscreenMode_;
+ // Tracks the currently requested system fullscreen mode, used to show or hide
+ // the menubar. This should be |kFullScreenModeNormal| when the window is not
+ // main or not fullscreen, |kFullScreenModeHideAll| while the overlay is
+ // hidden, and |kFullScreenModeHideDock| while the overlay is shown. If the
+ // window is not on the primary screen, this should always be
+ // |kFullScreenModeNormal|. This value can get out of sync with the correct
+ // state if we miss a notification (which can happen when a window is closed).
+ // Used to track the current state and make sure we properly restore the menu
+ // bar when this controller is destroyed.
+ base::mac::FullScreenMode systemFullscreenMode_;
}
-@property(readonly, nonatomic) BOOL isFullscreen;
+@property(readonly, nonatomic) BOOL inPresentationMode;
// Designated initializer.
- (id)initWithBrowserController:(BrowserWindowController*)controller;
-// Informs the controller that the browser has entered or exited fullscreen
-// mode. |-enterFullscreenForContentView:showDropdown:| should be called after
-// the fullscreen window is setup, just before it is shown. |-exitFullscreen|
+// Informs the controller that the browser has entered or exited presentation
+// mode. |-enterPresentationModeForContentView:showDropdown:| should be called
+// after the window is setup, just before it is shown. |-exitPresentationMode|
// should be called before any views are moved back to the non-fullscreen
-// window. If |-enterFullscreenForContentView:showDropdown:| is called, it must
-// be followed with a call to |-exitFullscreen| before the controller is
-// released.
-- (void)enterFullscreenForContentView:(NSView*)contentView
- showDropdown:(BOOL)showDropdown;
-- (void)exitFullscreen;
+// window. If |-enterPresentationModeForContentView:showDropdown:| is called,
+// it must be balanced with a call to |-exitPresentationMode| before the
+// controller is released.
+- (void)enterPresentationModeForContentView:(NSView*)contentView
+ showDropdown:(BOOL)showDropdown;
+- (void)exitPresentationMode;
// Returns the amount by which the floating bar should be offset downwards (to
// avoid the menu) and by which the overlay view should be enlarged vertically.
-// Generally, this is > 0 when the fullscreen window is on the primary screen
-// and 0 otherwise.
+// Generally, this is > 0 when the window is on the primary screen and 0
+// otherwise.
- (CGFloat)floatingBarVerticalOffset;
// Informs the controller that the overlay's frame has changed. The controller
@@ -110,7 +113,7 @@
- (CGFloat)floatingBarShownFraction;
// Sets a new current floating bar shown fraction. NOTE: This function has side
-// effects, such as modifying the fullscreen mode (menu bar shown state).
+// effects, such as modifying the system fullscreen mode (menu bar shown state).
- (void)changeFloatingBarShownFraction:(CGFloat)fraction;
@end
@@ -119,4 +122,4 @@
extern NSString* const kWillEnterFullscreenNotification;
extern NSString* const kWillLeaveFullscreenNotification;
-#endif // CHROME_BROWSER_UI_COCOA_FULLSCREEN_CONTROLLER_H_
+#endif // CHROME_BROWSER_UI_COCOA_PRESENTATION_MODE_CONTROLLER_H_

Powered by Google App Engine
This is Rietveld 408576698