blob: a3e42056aa38a24dd3dd63afc01e1b8dc2a52eef (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
|
// 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_PANELS_PANEL_MANAGER_H_
#define CHROME_BROWSER_UI_PANELS_PANEL_MANAGER_H_
#pragma once
#include <vector>
#include "base/basictypes.h"
#include "base/lazy_instance.h"
#include "base/memory/scoped_ptr.h"
#include "base/timer.h"
#include "chrome/browser/ui/panels/auto_hiding_desktop_bar.h"
#include "chrome/browser/ui/panels/panel.h"
#include "ui/gfx/rect.h"
class Browser;
class PanelMouseWatcher;
class PanelOverflowStrip;
class PanelStrip;
// This class manages a set of panels.
class PanelManager : public AutoHidingDesktopBar::Observer {
public:
// Returns a single instance.
static PanelManager* GetInstance();
// Returns true if panels should be used for the extension.
static bool ShouldUsePanels(const std::string& extension_id);
// Called when the display is changed, i.e. work area is updated.
void OnDisplayChanged();
// Creates a panel and returns it. The panel might be queued for display
// later.
Panel* CreatePanel(Browser* browser);
void Remove(Panel* panel);
void RemoveAll();
// Asynchronous confirmation of panel having been removed.
void OnPanelRemoved(Panel* panel);
// Drags the given panel.
void StartDragging(Panel* panel);
void Drag(int delta_x);
void EndDragging(bool cancelled);
// Invoked when a panel's expansion state changes.
void OnPanelExpansionStateChanged(Panel* panel,
Panel::ExpansionState old_state);
// Invoked when the preferred window size of the given panel might need to
// get changed.
void OnPreferredWindowSizeChanged(
Panel* panel, const gfx::Size& preferred_window_size);
// Returns true if we should bring up the titlebars, given the current mouse
// point.
bool ShouldBringUpTitlebars(int mouse_x, int mouse_y) const;
// Brings up or down the titlebars for all minimized panels.
void BringUpOrDownTitlebars(bool bring_up);
// Returns the next browser window which could be either panel window or
// tabbed window, to switch to if the given panel is going to be deactivated.
// Returns NULL if such window cannot be found.
BrowserWindow* GetNextBrowserWindowToActivate(Panel* panel) const;
int num_panels() const;
int StartingRightPosition() const;
std::vector<Panel*> panels() const;
AutoHidingDesktopBar* auto_hiding_desktop_bar() const {
return auto_hiding_desktop_bar_;
}
PanelMouseWatcher* mouse_watcher() const {
return panel_mouse_watcher_.get();
}
PanelStrip* panel_strip() const {
return panel_strip_.get();
}
bool is_full_screen() const { return is_full_screen_; }
PanelOverflowStrip* panel_overflow_strip() const {
return panel_overflow_strip_.get();
}
// Reduces time interval in tests to shorten test run time.
// Wrapper should be used around all time intervals in panels code.
static inline double AdjustTimeInterval(double interval) {
if (shorten_time_intervals_)
return interval / 100.0;
else
return interval;
}
#ifdef UNIT_TEST
static void shorten_time_intervals_for_testing() {
shorten_time_intervals_ = true;
}
void set_auto_hiding_desktop_bar(
AutoHidingDesktopBar* auto_hiding_desktop_bar) {
auto_hiding_desktop_bar_ = auto_hiding_desktop_bar;
}
void enable_auto_sizing(bool enabled) {
auto_sizing_enabled_ = enabled;
}
const gfx::Rect& work_area() const {
return work_area_;
}
void SetWorkAreaForTesting(const gfx::Rect& work_area) {
SetWorkArea(work_area);
}
void SetMouseWatcherForTesting(PanelMouseWatcher* watcher) {
SetMouseWatcher(watcher);
}
#endif
private:
friend struct base::DefaultLazyInstanceTraits<PanelManager>;
PanelManager();
virtual ~PanelManager();
// Overridden from AutoHidingDesktopBar::Observer:
virtual void OnAutoHidingDesktopBarThicknessChanged() OVERRIDE;
virtual void OnAutoHidingDesktopBarVisibilityChanged(
AutoHidingDesktopBar::Alignment alignment,
AutoHidingDesktopBar::Visibility visibility) OVERRIDE;
// Applies the new work area. This is called by OnDisplayChanged and the test
// code.
void SetWorkArea(const gfx::Rect& work_area);
// Adjusts the work area to exclude the influence of auto-hiding desktop bars.
void AdjustWorkAreaForAutoHidingDesktopBars();
// Positions the various groupings of panels.
void Layout();
// Tests if the current active app is in full screen mode.
void CheckFullScreenMode();
// Tests may want to use a mock panel mouse watcher.
void SetMouseWatcher(PanelMouseWatcher* watcher);
// Tests may want to shorten time intervals to reduce running time.
static bool shorten_time_intervals_;
scoped_ptr<PanelStrip> panel_strip_;
scoped_ptr<PanelOverflowStrip> panel_overflow_strip_;
// Use a mouse watcher to know when to bring up titlebars to "peek" at
// minimized panels. Mouse movement is only tracked when there is a minimized
// panel.
scoped_ptr<PanelMouseWatcher> panel_mouse_watcher_;
// The maximum work area avaialble. This area does not include the area taken
// by the always-visible (non-auto-hiding) desktop bars.
gfx::Rect work_area_;
// The useable work area for computing the panel bounds. This area excludes
// the potential area that could be taken by the auto-hiding desktop
// bars (we only consider those bars that are aligned to bottom, left, and
// right of the screen edges) when they become fully visible.
gfx::Rect adjusted_work_area_;
scoped_refptr<AutoHidingDesktopBar> auto_hiding_desktop_bar_;
// Whether or not bounds will be updated when the preferred content size is
// changed. The testing code could set this flag to false so that other tests
// will not be affected.
bool auto_sizing_enabled_;
// Timer used to track if the current active app is in full screen mode.
base::RepeatingTimer<PanelManager> full_screen_mode_timer_;
// True if current active app is in full screen mode.
bool is_full_screen_;
DISALLOW_COPY_AND_ASSIGN(PanelManager);
};
#endif // CHROME_BROWSER_UI_PANELS_PANEL_MANAGER_H_
|