1 // Copyright 2012 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 #ifndef CHROME_BROWSER_UI_GTK_BROWSER_WINDOW_GTK_H_ 6 #define CHROME_BROWSER_UI_GTK_BROWSER_WINDOW_GTK_H_ 7 8 #include <gtk/gtk.h> 9 10 #include <string> 11 12 #include "base/basictypes.h" 13 #include "base/compiler_specific.h" 14 #include "base/memory/scoped_ptr.h" 15 #include "base/prefs/pref_member.h" 16 #include "base/timer/timer.h" 17 #include "build/build_config.h" 18 #include "chrome/browser/devtools/devtools_window.h" 19 #include "chrome/browser/extensions/extension_keybinding_registry.h" 20 #include "chrome/browser/infobars/infobar_container.h" 21 #include "chrome/browser/ui/browser_window.h" 22 #include "chrome/browser/ui/host_desktop.h" 23 #include "chrome/browser/ui/tabs/tab_strip_model_observer.h" 24 #include "ui/base/gtk/gtk_signal.h" 25 #include "ui/base/ui_base_types.h" 26 #include "ui/base/x/active_window_watcher_x_observer.h" 27 #include "ui/base/x/x11_util.h" 28 #include "ui/gfx/rect.h" 29 30 class BookmarkBarGtk; 31 class Browser; 32 class BrowserTitlebar; 33 class BrowserToolbarGtk; 34 class DevToolsWindow; 35 class DownloadShelfGtk; 36 class ExtensionKeybindingRegistryGtk; 37 class FindBarGtk; 38 class FullscreenExitBubbleGtk; 39 class GlobalMenuBar; 40 class InfoBarContainerGtk; 41 class InstantOverlayControllerGtk; 42 class LocationBar; 43 class StatusBubbleGtk; 44 class TabContentsContainerGtk; 45 class TabStripGtk; 46 47 namespace autofill { 48 class PasswordGenerator; 49 } 50 51 namespace extensions { 52 class ActiveTabPermissionGranter; 53 class Extension; 54 } 55 56 namespace user_prefs { 57 class PrefRegistrySyncable; 58 } 59 60 // An implementation of BrowserWindow for GTK. Cross-platform code will interact 61 // with this object when it needs to manipulate the window. 62 class BrowserWindowGtk 63 : public BrowserWindow, 64 public content::NotificationObserver, 65 public TabStripModelObserver, 66 public ui::ActiveWindowWatcherXObserver, 67 public InfoBarContainer::Delegate, 68 public extensions::ExtensionKeybindingRegistry::Delegate { 69 public: 70 explicit BrowserWindowGtk(Browser* browser); 71 virtual ~BrowserWindowGtk(); 72 73 // Separating initialization from constructor. 74 void Init(); 75 76 // Overridden from BrowserWindow: 77 virtual void Show() OVERRIDE; 78 virtual void ShowInactive() OVERRIDE; 79 virtual void Hide() OVERRIDE; 80 virtual void SetBounds(const gfx::Rect& bounds) OVERRIDE; 81 virtual void Close() OVERRIDE; 82 virtual void Activate() OVERRIDE; 83 virtual void Deactivate() OVERRIDE; 84 virtual bool IsActive() const OVERRIDE; 85 virtual void FlashFrame(bool flash) OVERRIDE; 86 virtual bool IsAlwaysOnTop() const OVERRIDE; 87 virtual void SetAlwaysOnTop(bool always_on_top) OVERRIDE; 88 virtual gfx::NativeWindow GetNativeWindow() OVERRIDE; 89 virtual BrowserWindowTesting* GetBrowserWindowTesting() OVERRIDE; 90 virtual StatusBubble* GetStatusBubble() OVERRIDE; 91 virtual void UpdateTitleBar() OVERRIDE; 92 virtual void BookmarkBarStateChanged( 93 BookmarkBar::AnimateChangeType change_type) OVERRIDE; 94 virtual void UpdateDevTools() OVERRIDE; 95 virtual void UpdateLoadingAnimations(bool should_animate) OVERRIDE; 96 virtual void SetStarredState(bool is_starred) OVERRIDE; 97 virtual void SetTranslateIconToggled(bool is_lit) OVERRIDE; 98 virtual void OnActiveTabChanged(content::WebContents* old_contents, 99 content::WebContents* new_contents, 100 int index, 101 int reason) OVERRIDE; 102 virtual void ZoomChangedForActiveTab(bool can_show_bubble) OVERRIDE; 103 virtual gfx::Rect GetRestoredBounds() const OVERRIDE; 104 virtual ui::WindowShowState GetRestoredState() const OVERRIDE; 105 virtual gfx::Rect GetBounds() const OVERRIDE; 106 virtual bool IsMaximized() const OVERRIDE; 107 virtual bool IsMinimized() const OVERRIDE; 108 virtual void Maximize() OVERRIDE; 109 virtual void Minimize() OVERRIDE; 110 virtual void Restore() OVERRIDE; 111 virtual void EnterFullscreen( 112 const GURL& url, FullscreenExitBubbleType type) OVERRIDE; 113 virtual void ExitFullscreen() OVERRIDE; 114 virtual void UpdateFullscreenExitBubbleContent( 115 const GURL& url, 116 FullscreenExitBubbleType bubble_type) OVERRIDE; 117 virtual bool ShouldHideUIForFullscreen() const OVERRIDE; 118 virtual bool IsFullscreen() const OVERRIDE; 119 virtual bool IsFullscreenBubbleVisible() const OVERRIDE; 120 virtual LocationBar* GetLocationBar() const OVERRIDE; 121 virtual void SetFocusToLocationBar(bool select_all) OVERRIDE; 122 virtual void UpdateReloadStopState(bool is_loading, bool force) OVERRIDE; 123 virtual void UpdateToolbar(content::WebContents* contents) OVERRIDE; 124 virtual void FocusToolbar() OVERRIDE; 125 virtual void FocusAppMenu() OVERRIDE; 126 virtual void FocusBookmarksToolbar() OVERRIDE; 127 virtual void FocusInfobars() OVERRIDE; 128 virtual void RotatePaneFocus(bool forwards) OVERRIDE; 129 virtual bool IsBookmarkBarVisible() const OVERRIDE; 130 virtual bool IsBookmarkBarAnimating() const OVERRIDE; 131 virtual bool IsTabStripEditable() const OVERRIDE; 132 virtual bool IsToolbarVisible() const OVERRIDE; 133 virtual gfx::Rect GetRootWindowResizerRect() const OVERRIDE; 134 virtual void ConfirmAddSearchProvider(TemplateURL* template_url, 135 Profile* profile) OVERRIDE; 136 virtual void ShowUpdateChromeDialog() OVERRIDE; 137 virtual void ShowBookmarkBubble(const GURL& url, 138 bool already_bookmarked) OVERRIDE; 139 virtual void ShowTranslateBubble( 140 content::WebContents* contents, 141 TranslateBubbleModel::ViewState view_state, 142 TranslateErrors::Type error_type) OVERRIDE; 143 #if defined(ENABLE_ONE_CLICK_SIGNIN) 144 virtual void ShowOneClickSigninBubble( 145 OneClickSigninBubbleType type, 146 const base::string16& email, 147 const base::string16& error_message, 148 const StartSyncCallback& start_sync_callback) OVERRIDE; 149 #endif 150 virtual bool IsDownloadShelfVisible() const OVERRIDE; 151 virtual DownloadShelf* GetDownloadShelf() OVERRIDE; 152 virtual void ConfirmBrowserCloseWithPendingDownloads( 153 int download_count, 154 Browser::DownloadClosePreventionType dialog_type, 155 bool app_modal, 156 const base::Callback<void(bool)>& callback) OVERRIDE; 157 virtual void UserChangedTheme() OVERRIDE; 158 virtual int GetExtraRenderViewHeight() const OVERRIDE; 159 virtual void WebContentsFocused(content::WebContents* contents) OVERRIDE; 160 virtual void ShowWebsiteSettings(Profile* profile, 161 content::WebContents* web_contents, 162 const GURL& url, 163 const content::SSLStatus& ssl) OVERRIDE; 164 virtual void ShowAppMenu() OVERRIDE; 165 virtual bool PreHandleKeyboardEvent( 166 const content::NativeWebKeyboardEvent& event, 167 bool* is_keyboard_shortcut) OVERRIDE; 168 virtual void HandleKeyboardEvent( 169 const content::NativeWebKeyboardEvent& event) OVERRIDE; 170 virtual void Cut() OVERRIDE; 171 virtual void Copy() OVERRIDE; 172 virtual void Paste() OVERRIDE; 173 virtual WindowOpenDisposition GetDispositionForPopupBounds( 174 const gfx::Rect& bounds) OVERRIDE; 175 virtual FindBar* CreateFindBar() OVERRIDE; 176 virtual web_modal::WebContentsModalDialogHost* 177 GetWebContentsModalDialogHost() OVERRIDE; 178 virtual void ShowAvatarBubble(content::WebContents* web_contents, 179 const gfx::Rect& rect) OVERRIDE; 180 virtual void ShowAvatarBubbleFromAvatarButton() OVERRIDE; 181 virtual void ShowPasswordGenerationBubble( 182 const gfx::Rect& rect, 183 const autofill::PasswordForm& form, 184 autofill::PasswordGenerator* password_generator) OVERRIDE; 185 virtual int GetRenderViewHeightInsetWithDetachedBookmarkBar() OVERRIDE; 186 187 // Overridden from NotificationObserver: 188 virtual void Observe(int type, 189 const content::NotificationSource& source, 190 const content::NotificationDetails& details) OVERRIDE; 191 192 // Overridden from TabStripModelObserver: 193 virtual void TabDetachedAt(content::WebContents* contents, 194 int index) OVERRIDE; 195 196 // Overridden from ActiveWindowWatcherXObserver. 197 virtual void ActiveWindowChanged(GdkWindow* active_window) OVERRIDE; 198 199 // Overridden from InfoBarContainer::Delegate: 200 virtual SkColor GetInfoBarSeparatorColor() const OVERRIDE; 201 virtual void InfoBarContainerStateChanged(bool is_animating) OVERRIDE; 202 virtual bool DrawInfoBarArrows(int* x) const OVERRIDE; 203 204 // Overridden from ExtensionKeybindingRegistry::Delegate: 205 virtual extensions::ActiveTabPermissionGranter* 206 GetActiveTabPermissionGranter() OVERRIDE; 207 208 // Accessor for the tab strip. tabstrip()209 TabStripGtk* tabstrip() const { return tabstrip_.get(); } 210 211 void OnDebouncedBoundsChanged(); 212 213 // Request the underlying window to unmaximize. 214 void UnMaximize(); 215 216 // Returns false if we're not ready to close yet. E.g., a tab may have an 217 // onbeforeunload handler that prevents us from closing. 218 bool CanClose() const; 219 220 // Returns whether to draw the content drop shadow on the sides and bottom 221 // of the browser window. When false, we still draw a shadow on the top of 222 // the toolbar (under the tab strip), but do not round the top corners. 223 bool ShouldDrawContentDropShadow() const; 224 225 bool ShouldShowWindowIcon() const; 226 227 // Add the find bar widget to the window hierarchy. 228 void AddFindBar(FindBarGtk* findbar); 229 230 // Reset the mouse cursor to the default cursor if it was set to something 231 // else for the custom frame. 232 void ResetCustomFrameCursor(); 233 234 // Returns the BrowserWindowGtk registered with |window|. 235 static BrowserWindowGtk* GetBrowserWindowForNativeWindow( 236 gfx::NativeWindow window); 237 238 // Retrieves the GtkWindow associated with |xid|, which is the X Window 239 // ID of the top-level X window of this object. 240 static GtkWindow* GetBrowserWindowForXID(XID xid); 241 browser()242 Browser* browser() const { return browser_.get(); } 243 window()244 GtkWindow* window() const { return window_; } 245 titlebar()246 BrowserTitlebar* titlebar() const { return titlebar_.get(); } 247 248 GtkWidget* titlebar_widget() const; 249 GetToolbar()250 BrowserToolbarGtk* GetToolbar() { return toolbar_.get(); } 251 bounds()252 gfx::Rect bounds() const { return bounds_; } 253 254 // Returns the tab we're currently displaying in the tab contents container. 255 content::WebContents* GetDisplayedTab(); 256 257 static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry); 258 259 // Tells GTK that the toolbar area is invalidated and needs redrawing. We 260 // have this method as a hack because GTK doesn't queue the toolbar area for 261 // redraw when it should. 262 void QueueToolbarRedraw(); 263 264 // Get the position where the infobar arrow should be anchored in 265 // |relative_to| coordinates. This is the middle of the omnibox location icon. 266 int GetXPositionOfLocationIcon(GtkWidget* relative_to); 267 268 // Show or hide the bookmark bar. 269 void MaybeShowBookmarkBar(bool animate); 270 271 protected: 272 virtual void DestroyBrowser() OVERRIDE; 273 274 // Checks to see if the mouse pointer at |x|, |y| is over the border of the 275 // custom frame (a spot that should trigger a window resize). Returns true if 276 // it should and sets |edge|. 277 bool GetWindowEdge(int x, int y, GdkWindowEdge* edge); 278 279 // Returns the window shape for the window with |width| and |height|. 280 // The caller is responsible for destroying the region if non-null region is 281 // returned. 282 GdkRegion* GetWindowShape(int width, int height) const; 283 284 // Save the window position in the prefs. 285 void SaveWindowPosition(); 286 287 // Sets the default size for the window and the way the user is allowed to 288 // resize it. 289 void SetGeometryHints(); 290 291 // Returns |true| if we should use the custom frame. 292 bool UseCustomFrame() const; 293 294 // Invalidate window to force repaint. 295 void InvalidateWindow(); 296 297 // Top level window. NULL after the window starts closing. 298 GtkWindow* window_; 299 // Determines whether window was shown. 300 bool window_has_shown_; 301 // GtkAlignment that holds the interior components of the chromium window. 302 // This is used to draw the custom frame border and content shadow. Owned by 303 // window_. 304 GtkWidget* window_container_; 305 // VBox that holds everything (tabs, toolbar, bookmarks bar, tab contents). 306 // Owned by window_container_. 307 GtkWidget* window_vbox_; 308 // VBox that holds everything below the toolbar. Owned by 309 // render_area_floating_container_. 310 GtkWidget* render_area_vbox_; 311 // Floating container that holds the render area. It is needed to position 312 // the findbar. Owned by render_area_event_box_. 313 GtkWidget* render_area_floating_container_; 314 // EventBox that holds render_area_floating_container_. Owned by window_vbox_. 315 GtkWidget* render_area_event_box_; 316 // Border between toolbar and render area. Owned by render_area_vbox_. 317 GtkWidget* toolbar_border_; 318 319 scoped_ptr<Browser> browser_; 320 321 private: 322 // Connect to signals on |window_|. 323 void ConnectHandlersToSignals(); 324 325 // Create the various UI components. 326 void InitWidgets(); 327 328 // Set up background color of the window (depends on if we're incognito or 329 // not). 330 void SetBackgroundColor(); 331 332 // Applies the window shape to if we're in custom drawing mode. 333 void UpdateWindowShape(int width, int height); 334 335 // Connect accelerators that aren't connected to menu items (like ctrl-o, 336 // ctrl-l, etc.). 337 void ConnectAccelerators(); 338 339 // Whether we should draw the tab background instead of the theme_frame 340 // background because this window is a popup. 341 bool UsingCustomPopupFrame() const; 342 343 // Draws the normal custom frame using theme_frame. 344 void DrawCustomFrame(cairo_t* cr, GtkWidget* widget, GdkEventExpose* event); 345 346 // Draws the tab image as the frame so we can write legible text. 347 void DrawPopupFrame(cairo_t* cr, GtkWidget* widget, GdkEventExpose* event); 348 349 // Draws the border, including resizable corners, for the custom frame. 350 void DrawCustomFrameBorder(GtkWidget* widget); 351 352 // Change whether we're showing the custom blue frame. 353 // Must be called once at startup. 354 // Triggers relayout of the content. 355 void UpdateCustomFrame(); 356 357 // Set the bounds of the current window. If |exterior| is true, set the size 358 // of the window itself, otherwise set the bounds of the web contents. 359 // If |move| is true, set the position of the window, otherwise leave the 360 // position to the WM. 361 void SetBoundsImpl(const gfx::Rect& bounds, bool exterior, bool move); 362 363 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnConfigure, 364 GdkEventConfigure*); 365 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnWindowState, 366 GdkEventWindowState*); 367 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnMainWindowDeleteEvent, 368 GdkEvent*); 369 CHROMEGTK_CALLBACK_0(BrowserWindowGtk, void, OnMainWindowDestroy); 370 // Callback for when the custom frame alignment needs to be redrawn. 371 // The content area includes the toolbar and web page but not the tab strip. 372 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnCustomFrameExpose, 373 GdkEventExpose*); 374 375 // A helper method that draws the shadow above the toolbar and in the frame 376 // border during an expose. 377 void DrawContentShadow(cairo_t* cr); 378 379 // The background frame image needs to be offset by the size of the top of 380 // the window to the top of the tabs when the full skyline isn't displayed 381 // for some reason. 382 int GetVerticalOffset(); 383 384 // Returns which frame image we should use based on the window's current 385 // activation state / incognito state. 386 int GetThemeFrameResource(); 387 388 // Invalidate all the widgets that need to redraw when the infobar draw state 389 // has changed. 390 void InvalidateInfoBarBits(); 391 392 // When the location icon moves, we have to redraw the arrow. 393 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, void, OnLocationIconSizeAllocate, 394 GtkAllocation*); 395 396 // Used to draw the infobar arrow and drop shadow. This is connected to 397 // multiple widgets' expose events because it overlaps several widgets. 398 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnExposeDrawInfobarBits, 399 GdkEventExpose*); 400 401 // Used to draw the infobar bits for the bookmark bar. When the bookmark 402 // bar is in floating mode, it has to draw a drop shadow only; otherwise 403 // it is responsible for its portion of the arrow as well as some shadowing. 404 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnBookmarkBarExpose, 405 GdkEventExpose*); 406 407 // Callback for "size-allocate" signal on bookmark bar; this is relevant 408 // because when the bookmark bar changes dimensions, the infobar arrow has to 409 // change its shape, and we need to queue appropriate redraws. 410 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, void, OnBookmarkBarSizeAllocate, 411 GtkAllocation*); 412 413 // Callback for accelerator activation. |user_data| stores the command id 414 // of the matched accelerator. 415 static gboolean OnGtkAccelerator(GtkAccelGroup* accel_group, 416 GObject* acceleratable, 417 guint keyval, 418 GdkModifierType modifier, 419 void* user_data); 420 421 // Key press event callback. 422 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnKeyPress, GdkEventKey*); 423 424 // Mouse move and mouse button press callbacks. 425 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnMouseMoveEvent, 426 GdkEventMotion*); 427 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnButtonPressEvent, 428 GdkEventButton*); 429 430 // Tracks focus state of browser. 431 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnFocusIn, 432 GdkEventFocus*); 433 CHROMEGTK_CALLBACK_1(BrowserWindowGtk, gboolean, OnFocusOut, 434 GdkEventFocus*); 435 436 // Callback for the loading animation(s) associated with this window. 437 void LoadingAnimationCallback(); 438 439 // Shows UI elements for supported window features. 440 void ShowSupportedWindowFeatures(); 441 442 // Hides UI elements for unsupported window features. 443 void HideUnsupportedWindowFeatures(); 444 445 // Helper functions that query |browser_| concerning support for UI features 446 // in this window. (For example, a popup window might not support a tabstrip). 447 bool IsTabStripSupported() const; 448 bool IsToolbarSupported() const; 449 bool IsBookmarkBarSupported() const; 450 451 // Put the bookmark bar where it belongs. 452 void PlaceBookmarkBar(bool is_floating); 453 454 // Decides if we should draw the frame as if the window is active. 455 bool DrawFrameAsActive() const; 456 457 // Updates devtools window for given contents. This method will show docked 458 // devtools window for inspected |contents| that has docked devtools 459 // and hide it for NULL or not inspected |contents|. It will also make 460 // sure devtools window size and position are restored for given tab. 461 void UpdateDevToolsForContents(content::WebContents* contents); 462 463 // Shows docked devtools. 464 void ShowDevToolsContainer(); 465 466 // Hides docked devtools. 467 void HideDevToolsContainer(); 468 469 // Reads split position from the current tab's devtools window and applies 470 // it to the devtools split. 471 void UpdateDevToolsSplitPosition(); 472 473 // Called when the preference changes. 474 void OnUseCustomChromeFrameChanged(); 475 476 // Determine whether we use should default to native decorations or the custom 477 // frame based on the currently-running window manager. 478 static bool GetCustomFramePrefDefault(); 479 480 // The position and size of the current window. 481 gfx::Rect bounds_; 482 483 // The configure bounds of the current window, used to figure out whether to 484 // ignore later configure events. See OnConfigure() for more information. 485 gfx::Rect configure_bounds_; 486 487 // The position and size of the non-maximized, non-fullscreen window. 488 gfx::Rect restored_bounds_; 489 490 GdkWindowState state_; 491 492 // Controls a hidden GtkMenuBar that we keep updated so GNOME can take a look 493 // inside "our menu bar" and present it in the top panel, akin to Mac OS. 494 scoped_ptr<GlobalMenuBar> global_menu_bar_; 495 496 // The container for the titlebar + tab strip. 497 scoped_ptr<BrowserTitlebar> titlebar_; 498 499 // The object that manages all of the widgets in the toolbar. 500 scoped_ptr<BrowserToolbarGtk> toolbar_; 501 502 // The object that manages the bookmark bar. This will be NULL if the 503 // bookmark bar is not supported. 504 scoped_ptr<BookmarkBarGtk> bookmark_bar_; 505 506 // The download shelf view (view at the bottom of the page). 507 scoped_ptr<DownloadShelfGtk> download_shelf_; 508 509 // The status bubble manager. Always non-NULL. 510 scoped_ptr<StatusBubbleGtk> status_bubble_; 511 512 // A container that manages the GtkWidget*s that are the webpage display 513 // (along with associated infobars, shelves, and other things that are part 514 // of the content area). 515 scoped_ptr<TabContentsContainerGtk> contents_container_; 516 517 // A container that manages the GtkWidget*s of developer tools for the 518 // selected tab contents. 519 scoped_ptr<TabContentsContainerGtk> devtools_container_; 520 521 // The Extension Keybinding Registry responsible for registering listeners for 522 // accelerators that are sent to the window, that are destined to be turned 523 // into events and sent to the extension. 524 scoped_ptr<ExtensionKeybindingRegistryGtk> extension_keybinding_registry_; 525 526 DevToolsDockSide devtools_dock_side_; 527 528 // Docked devtools window instance. NULL when current tab is not inspected 529 // or is inspected with undocked version of DevToolsWindow. 530 DevToolsWindow* devtools_window_; 531 532 // Split pane containing the contents_container_ and the devtools_container_. 533 // Owned by contents_vsplit_. 534 GtkWidget* contents_hsplit_; 535 536 // Split pane containing the contents_hsplit_ and the devtools_container_. 537 // Owned by render_area_vbox_. 538 GtkWidget* contents_vsplit_; 539 540 // The tab strip. Always non-NULL. 541 scoped_ptr<TabStripGtk> tabstrip_; 542 543 // The container for info bars. Always non-NULL. 544 scoped_ptr<InfoBarContainerGtk> infobar_container_; 545 546 // The timer used to update frames for the Loading Animation. 547 base::RepeatingTimer<BrowserWindowGtk> loading_animation_timer_; 548 549 // The timer used to save the window position for session restore. 550 base::OneShotTimer<BrowserWindowGtk> window_configure_debounce_timer_; 551 552 // Whether the custom chrome frame pref is set. Normally you want to use 553 // UseCustomFrame() above to determine whether to use the custom frame or 554 // not. 555 BooleanPrefMember use_custom_frame_pref_; 556 557 // The current window cursor. We set it to a resize cursor when over the 558 // custom frame border. We set it to NULL if we want the default cursor. 559 GdkCursor* frame_cursor_; 560 561 // True if the window manager thinks the window is active. Not all window 562 // managers keep track of this state (_NET_ACTIVE_WINDOW), in which case 563 // this will always be true. 564 bool is_active_; 565 566 // Optionally maximize or minimize the window after we call 567 // BrowserWindow::Show for the first time. This is to work around a compiz 568 // bug. 569 ui::WindowShowState show_state_after_show_; 570 571 // If true, don't call gdk_window_raise() when we get a click in the title 572 // bar or window border. This is to work around a compiz bug. 573 bool suppress_window_raise_; 574 575 // The accelerator group used to handle accelerators, owned by this object. 576 GtkAccelGroup* accel_group_; 577 578 // Set to true while this BrowserWindowGtk is fullscreened. This is needed 579 // because GTK cannot ensure requests to fullscreen the window will be honored 580 // by all window managers; and therefore bit-testing |state_| is not a 581 // reliable "is fullscreened" test. http://crbug.com/286545 582 bool is_fullscreen_; 583 584 scoped_ptr<FullscreenExitBubbleGtk> fullscreen_exit_bubble_; 585 586 content::NotificationRegistrar registrar_; 587 588 DISALLOW_COPY_AND_ASSIGN(BrowserWindowGtk); 589 }; 590 591 #endif // CHROME_BROWSER_UI_GTK_BROWSER_WINDOW_GTK_H_ 592