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
|
// Copyright (c) 2010 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.
#include "chrome/browser/views/frame/browser_frame_gtk.h"
#include "app/gfx/font.h"
#include "base/logging.h"
#include "chrome/browser/browser_theme_provider.h"
#include "chrome/browser/profile.h"
#include "chrome/browser/status_bubble.h"
#include "chrome/browser/views/frame/app_panel_browser_frame_view.h"
#include "chrome/browser/views/frame/browser_extender.h"
#include "chrome/browser/views/frame/browser_root_view.h"
#include "chrome/browser/views/frame/browser_view.h"
#include "chrome/browser/views/frame/opaque_browser_frame_view.h"
#include "views/widget/root_view.h"
#include "views/window/hit_test.h"
namespace {
// BrowserNonClientFrameView implementation for popups. We let the window
// manager implementation render the decorations for popups, so this draws
// nothing.
class PopupNonClientFrameView : public BrowserNonClientFrameView {
public:
PopupNonClientFrameView() {
}
// NonClientFrameView:
virtual gfx::Rect GetBoundsForClientView() const {
return gfx::Rect(0, 0, width(), height());
}
virtual bool AlwaysUseCustomFrame() const { return false; }
virtual bool AlwaysUseNativeFrame() const { return true; }
virtual gfx::Rect GetWindowBoundsForClientBounds(
const gfx::Rect& client_bounds) const {
return client_bounds;
}
virtual int NonClientHitTest(const gfx::Point& point) {
return bounds().Contains(point) ? HTCLIENT : HTNOWHERE;
}
virtual void GetWindowMask(const gfx::Size& size,
gfx::Path* window_mask) {}
virtual void EnableClose(bool enable) {}
virtual void ResetWindowControls() {}
// BrowserNonClientFrameView:
virtual gfx::Rect GetBoundsForTabStrip(BaseTabStrip* tabstrip) const {
return gfx::Rect(0, 0, width(), tabstrip->GetPreferredHeight());
}
virtual void UpdateThrobber(bool running) {}
private:
DISALLOW_COPY_AND_ASSIGN(PopupNonClientFrameView);
};
}
#if !defined(OS_CHROMEOS)
// static (Factory method.)
BrowserFrame* BrowserFrame::Create(BrowserView* browser_view,
Profile* profile) {
BrowserFrameGtk* frame = new BrowserFrameGtk(browser_view, profile);
frame->Init();
return frame;
}
#endif
// static
const gfx::Font& BrowserFrame::GetTitleFont() {
static gfx::Font *title_font = new gfx::Font();
return *title_font;
}
BrowserFrameGtk::BrowserFrameGtk(BrowserView* browser_view, Profile* profile)
: WindowGtk(browser_view),
browser_view_(browser_view),
browser_frame_view_(NULL),
root_view_(NULL),
profile_(profile) {
browser_view_->set_frame(this);
}
BrowserFrameGtk::~BrowserFrameGtk() {
}
void BrowserFrameGtk::Init() {
if (browser_frame_view_ == NULL) {
if (browser_view_->browser()->type() == Browser::TYPE_POPUP)
browser_frame_view_ = new PopupNonClientFrameView();
else
browser_frame_view_ = new OpaqueBrowserFrameView(this, browser_view_);
}
GetNonClientView()->SetFrameView(browser_frame_view_);
WindowGtk::Init(NULL, gfx::Rect());
// Don't focus anything on creation, selecting a tab will set the focus.
}
views::Window* BrowserFrameGtk::GetWindow() {
return this;
}
void BrowserFrameGtk::TabStripCreated(BaseTabStrip* tabstrip) {
}
int BrowserFrameGtk::GetMinimizeButtonOffset() const {
NOTIMPLEMENTED();
return 0;
}
gfx::Rect BrowserFrameGtk::GetBoundsForTabStrip(BaseTabStrip* tabstrip) const {
return browser_frame_view_->GetBoundsForTabStrip(tabstrip);
}
void BrowserFrameGtk::UpdateThrobber(bool running) {
browser_frame_view_->UpdateThrobber(running);
}
void BrowserFrameGtk::ContinueDraggingDetachedTab() {
NOTIMPLEMENTED();
}
ThemeProvider* BrowserFrameGtk::GetThemeProviderForFrame() const {
// This is implemented for a different interface than GetThemeProvider is,
// but they mean the same things.
return GetThemeProvider();
}
bool BrowserFrameGtk::AlwaysUseNativeFrame() const {
return false;
}
views::View* BrowserFrameGtk::GetFrameView() const {
return browser_frame_view_;
}
ThemeProvider* BrowserFrameGtk::GetThemeProvider() const {
return profile_->GetThemeProvider();
}
ThemeProvider* BrowserFrameGtk::GetDefaultThemeProvider() const {
return profile_->GetThemeProvider();
}
views::RootView* BrowserFrameGtk::CreateRootView() {
root_view_ = new BrowserRootView(browser_view_, this);
return root_view_;
}
void BrowserFrameGtk::IsActiveChanged() {
GetRootView()->SchedulePaint();
browser_view_->ActivationChanged(IsActive());
views::WidgetGtk::IsActiveChanged();
}
bool BrowserFrameGtk::GetAccelerator(int cmd_id,
menus::Accelerator* accelerator) {
return browser_view_->GetAccelerator(cmd_id, accelerator);
}
gboolean BrowserFrameGtk::OnWindowStateEvent(GtkWidget* widget,
GdkEventWindowState* event) {
bool was_full_screen = IsFullscreen();
gboolean result = views::WindowGtk::OnWindowStateEvent(widget, event);
if ((!IsVisible() || IsMinimized()) && browser_view_->GetStatusBubble()) {
// The window is effectively hidden. We have to hide the status bubble as
// unlike windows gtk has no notion of child windows that are hidden along
// with the parent.
browser_view_->GetStatusBubble()->Hide();
}
if (was_full_screen != IsFullscreen())
browser_view_->FullScreenStateChanged();
return result;
}
gboolean BrowserFrameGtk::OnConfigureEvent(GtkWidget* widget,
GdkEventConfigure* event) {
browser_view_->WindowMoved();
return views::WindowGtk::OnConfigureEvent(widget, event);
}
|