// 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_CHROMEOS_WM_OVERVIEW_CONTROLLER_H_ #define CHROME_BROWSER_CHROMEOS_WM_OVERVIEW_CONTROLLER_H_ #pragma once #include <vector> #include "base/memory/linked_ptr.h" #include "base/memory/singleton.h" #include "base/timer.h" #include "chrome/browser/chromeos/wm_message_listener.h" #include "chrome/browser/ui/browser_list.h" #include "content/common/notification_registrar.h" #include "ui/gfx/rect.h" namespace views { class Widget; } class Browser; class RenderWidgetHost; namespace chromeos { class BrowserListener; // WmOverviewController is responsible for managing a list of objects // that listen to the browsers (BrowserListeners, defined in the // source file for this class) for changes, and keep a list of // snapshot images in sync with the browser tab contents. // // As tabs are added/removed from the browsers, the number of snapshot // windows changes to match. // // As obtaining and setting snapshots is expensive we delay setting // the snapshot. The delay is controlled by delay_timer_. Once the // timer fires another timer is started (configure_timer_). This timer // invokes ConfigureNextUnconfiguredCell on the BrowserListener, which // obtains and sets the snapshot of the next uncofigured // cell. ConfigureNextUnconfiguredCell only configures one cell at a // time until they are all configured. class WmOverviewController : public BrowserList::Observer, public WmMessageListener::Observer, public NotificationObserver { public: // These are the possible layout modes that this controller can be // in. The layout mode is controlled by the window manager. enum LayoutMode { // ACTIVE_MODE is the mode where chrome takes up the whole screen // and the user interacts with it, and this controller hides the // snapshots and stops refreshing them. ACTIVE_MODE, // OVERVIEW_MODE is the mode where the toplevel windows are hidden // and the user interacts with the snapshots. This is when the // snapshot windows are shown and actively updated by this // controller. OVERVIEW_MODE, }; // This class is a singleton. static WmOverviewController* GetInstance(); // BrowserList::Observer methods void OnBrowserAdded(const Browser* browser) {} void OnBrowserRemoved(const Browser* browser); // End BrowserList::Observer methods // WmMessageListener::Observer methods // This is called immediately after a browser is added to the list. void ProcessWmMessage(const WmIpc::Message& message, GdkWindow* window); // End WmMessageListener::Observer methods // NotificationObserver methods void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); // End NotificationObserver methods // Used by the BrowserListeners to configure their snapshots. const gfx::Rect& monitor_bounds() const { return monitor_bounds_; } // Start reloading snapshots if in overview mode. void UpdateSnapshots(); // Starts the delay timer, and once the delay is over, configures // any unconfigured snapshots one at a time until none are left to // be configured. void StartDelayTimer(); LayoutMode layout_mode() const { return layout_mode_; } private: friend struct DefaultSingletonTraits<WmOverviewController>; // This class is a singleton. WmOverviewController(); ~WmOverviewController(); // Restores tab selections on all browsers to what they were when // Show was last called. Used when cancelling overview mode. void RestoreTabSelections(); // Saves the currently selected tabs in the snapshots so that they // can be restored later with RestoreTabSelections. void SaveTabSelections(); // Show the snapshot windows, saving current tab selections. void Show(); // Hide the snapshot windows. When |cancelled| is true, then the // tab selections that were saved when the snapshot windows were // shown are restored. void Hide(bool cancelled); // Add browser listeners for all existing browsers, reusing any that // were already there. void AddAllBrowsers(); // Called when the thumbnail generator notifies us that the snapshot // image changed. This determines which TabContents the given // renderer is attached to, and reloads that snapshot. void SnapshotImageChanged(RenderWidgetHost* renderer); // This is so we can register for notifications. NotificationRegistrar registrar_; // This is a vector of listeners that listen to all the browsers. typedef std::vector<linked_ptr<BrowserListener> > BrowserListenerVector; BrowserListenerVector listeners_; // This is the bounds of the monitor we're being displayed on. This // is used to adjust the size of snapshots so they'll fit. gfx::Rect monitor_bounds_; // See description above class for details. base::OneShotTimer<WmOverviewController> delay_timer_; // The current layout mode. LayoutMode layout_mode_; // This flag is set whenever there is a pending |AskForSnapshot| to Chrome; // This is used to prevent |UpdateSnapshots| from being called multiple times. bool updating_snapshots_; // These indices are used to track the last updated browser listener and tab // content, They are used to implement update tab contents in a round-robin // fashion. int browser_listener_index_; // index of the last updated browser listener. int tab_contents_index_; // index of the last updated tab contents. DISALLOW_COPY_AND_ASSIGN(WmOverviewController); }; } // namespace chromeos #endif // CHROME_BROWSER_CHROMEOS_WM_OVERVIEW_CONTROLLER_H_