blob: 4535867cfe9cb957347872dfa73df8974362e841 (
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
|
// 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 "base/logging.h"
#include "views/window/client_view.h"
#if defined(OS_LINUX)
#include "views/window/hit_test.h"
#endif
#include "views/window/window.h"
#include "views/window/window_delegate.h"
namespace views {
///////////////////////////////////////////////////////////////////////////////
// ClientView, public:
ClientView::ClientView(Window* window, View* contents_view)
: window_(window),
contents_view_(contents_view) {
}
int ClientView::NonClientHitTest(const gfx::Point& point) {
return bounds().Contains(point) ? HTCLIENT : HTNOWHERE;
}
void ClientView::WindowClosing() {
window_->GetDelegate()->WindowClosing();
}
///////////////////////////////////////////////////////////////////////////////
// ClientView, View overrides:
gfx::Size ClientView::GetPreferredSize() {
// |contents_view_| is allowed to be NULL up until the point where this view
// is attached to a Container.
if (contents_view_)
return contents_view_->GetPreferredSize();
return gfx::Size();
}
void ClientView::Layout() {
// |contents_view_| is allowed to be NULL up until the point where this view
// is attached to a Container.
if (contents_view_)
contents_view_->SetBounds(0, 0, width(), height());
}
void ClientView::ViewHierarchyChanged(bool is_add, View* parent, View* child) {
if (is_add && child == this) {
DCHECK(GetWidget());
DCHECK(contents_view_); // |contents_view_| must be valid now!
// Insert |contents_view_| at index 0 so it is first in the focus chain.
// (the OK/Cancel buttons are inserted before contents_view_)
AddChildView(0, contents_view_);
}
}
void ClientView::DidChangeBounds(const gfx::Rect& previous,
const gfx::Rect& current) {
// Overridden to do nothing. The NonClientView manually calls Layout on the
// ClientView when it is itself laid out, see comment in
// NonClientView::Layout.
}
AccessibilityTypes::Role ClientView::GetAccessibleRole() {
return AccessibilityTypes::ROLE_CLIENT;
}
} // namespace views
|