diff options
author | ben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-03-17 01:44:36 +0000 |
---|---|---|
committer | ben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-03-17 01:44:36 +0000 |
commit | 0e8588c1528cad6732d172775aba8e891baebdef (patch) | |
tree | a854c8ecdd0ab23cd4e6f9d9b2af94cbcaba12cb /chrome/views/window/client_view.cc | |
parent | 72c83ac9e7acbb70ab987ed81d03c5f6a47d203b (diff) | |
download | chromium_src-0e8588c1528cad6732d172775aba8e891baebdef.zip chromium_src-0e8588c1528cad6732d172775aba8e891baebdef.tar.gz chromium_src-0e8588c1528cad6732d172775aba8e891baebdef.tar.bz2 |
Move windowing related objects into chrome/views/window subdir.
TBR=sky
Review URL: http://codereview.chromium.org/42272
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@11819 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/views/window/client_view.cc')
-rw-r--r-- | chrome/views/window/client_view.cc | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/chrome/views/window/client_view.cc b/chrome/views/window/client_view.cc new file mode 100644 index 0000000..37ae937 --- /dev/null +++ b/chrome/views/window/client_view.cc @@ -0,0 +1,61 @@ +// Copyright (c) 2006-2008 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 "chrome/views/window/client_view.h" +#include "chrome/views/window/window.h" +#include "chrome/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! + AddChildView(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. +} + +} // namespace views |