Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "ui/views/controls/native/native_view_host_aura.h" | 5 #include "ui/views/controls/native/native_view_host_aura.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "ui/aura/client/aura_constants.h" | 8 #include "ui/aura/client/aura_constants.h" |
| 9 #include "ui/aura/client/focus_client.h" | 9 #include "ui/aura/client/focus_client.h" |
| 10 #include "ui/aura/layout_manager.h" | |
| 10 #include "ui/aura/window.h" | 11 #include "ui/aura/window.h" |
| 11 #include "ui/base/cursor/cursor.h" | 12 #include "ui/base/cursor/cursor.h" |
| 12 #include "ui/views/controls/native/native_view_host.h" | 13 #include "ui/views/controls/native/native_view_host.h" |
| 13 #include "ui/views/view_constants_aura.h" | 14 #include "ui/views/view_constants_aura.h" |
| 14 #include "ui/views/widget/widget.h" | 15 #include "ui/views/widget/widget.h" |
| 15 | 16 |
| 16 namespace views { | 17 namespace views { |
| 17 | 18 |
| 19 namespace { | |
| 20 | |
| 21 // This layout manager positions children relative to their grandparent's | |
| 22 // coordinate system. | |
| 23 class OffsettingLayoutManager : public aura::LayoutManager { | |
|
sky
2014/07/17 21:46:03
Seems heavyweight to create this rather than conve
Evan Stade
2014/07/17 22:50:35
yes, but converting on 136 doesn't work for the au
| |
| 24 public: | |
| 25 OffsettingLayoutManager() {} | |
| 26 virtual ~OffsettingLayoutManager() {} | |
| 27 | |
| 28 virtual void OnWindowResized() OVERRIDE {} | |
| 29 virtual void OnWindowAddedToLayout(aura::Window* child) OVERRIDE {} | |
| 30 virtual void OnWillRemoveWindowFromLayout(aura::Window* child) OVERRIDE {} | |
| 31 virtual void OnWindowRemovedFromLayout(aura::Window* child) OVERRIDE {} | |
| 32 virtual void OnChildWindowVisibilityChanged(aura::Window* child, | |
| 33 bool visible) OVERRIDE {} | |
| 34 virtual void SetChildBounds(aura::Window* child, | |
| 35 const gfx::Rect& requested_bounds) OVERRIDE { | |
| 36 gfx::Point origin = requested_bounds.origin(); | |
| 37 gfx::Point this_origin = child->parent()->GetTargetBounds().origin(); | |
| 38 origin.Offset(-this_origin.x(), -this_origin.y()); | |
| 39 SetChildBoundsDirect(child, gfx::Rect(origin, requested_bounds.size())); | |
| 40 } | |
| 41 }; | |
| 42 | |
| 43 } // namespace | |
| 44 | |
| 18 NativeViewHostAura::NativeViewHostAura(NativeViewHost* host) | 45 NativeViewHostAura::NativeViewHostAura(NativeViewHost* host) |
| 19 : host_(host), | 46 : host_(host), |
| 20 clipping_window_(NULL) { | 47 clipping_window_(NULL) { |
| 21 clipping_window_.Init(aura::WINDOW_LAYER_NOT_DRAWN); | 48 clipping_window_.Init(aura::WINDOW_LAYER_NOT_DRAWN); |
| 49 clipping_window_.SetLayoutManager(new OffsettingLayoutManager()); | |
| 22 clipping_window_.set_owned_by_parent(false); | 50 clipping_window_.set_owned_by_parent(false); |
| 23 clipping_window_.SetName("NativeViewHostAuraClip"); | 51 clipping_window_.SetName("NativeViewHostAuraClip"); |
| 24 clipping_window_.layer()->SetMasksToBounds(true); | 52 clipping_window_.layer()->SetMasksToBounds(true); |
| 25 clipping_window_.SetProperty(views::kHostViewKey, static_cast<View*>(host_)); | 53 clipping_window_.SetProperty(views::kHostViewKey, static_cast<View*>(host_)); |
| 26 } | 54 } |
| 27 | 55 |
| 28 NativeViewHostAura::~NativeViewHostAura() { | 56 NativeViewHostAura::~NativeViewHostAura() { |
| 29 if (host_->native_view()) { | 57 if (host_->native_view()) { |
| 30 host_->native_view()->RemoveObserver(this); | 58 host_->native_view()->RemoveObserver(this); |
| 31 host_->native_view()->ClearProperty(views::kHostViewKey); | 59 host_->native_view()->ClearProperty(views::kHostViewKey); |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 98 if (host_->fast_resize()) { | 126 if (host_->fast_resize()) { |
| 99 gfx::Point origin(x, y); | 127 gfx::Point origin(x, y); |
| 100 views::View::ConvertPointFromWidget(host_, &origin); | 128 views::View::ConvertPointFromWidget(host_, &origin); |
| 101 InstallClip(origin.x(), origin.y(), w, h); | 129 InstallClip(origin.x(), origin.y(), w, h); |
| 102 width = host_->native_view()->bounds().width(); | 130 width = host_->native_view()->bounds().width(); |
| 103 height = host_->native_view()->bounds().height(); | 131 height = host_->native_view()->bounds().height(); |
| 104 } | 132 } |
| 105 clipping_window_.SetBounds(clip_rect_ ? *clip_rect_ | 133 clipping_window_.SetBounds(clip_rect_ ? *clip_rect_ |
| 106 : gfx::Rect(x, y, w, h)); | 134 : gfx::Rect(x, y, w, h)); |
| 107 | 135 |
| 108 gfx::Point clip_offset = clipping_window_.bounds().origin(); | 136 host_->native_view()->SetBounds(gfx::Rect(x, y, width, height)); |
| 109 host_->native_view()->SetBounds( | |
| 110 gfx::Rect(x - clip_offset.x(), y - clip_offset.y(), width, height)); | |
| 111 host_->native_view()->Show(); | 137 host_->native_view()->Show(); |
| 112 } | 138 } |
| 113 | 139 |
| 114 void NativeViewHostAura::HideWidget() { | 140 void NativeViewHostAura::HideWidget() { |
| 115 host_->native_view()->Hide(); | 141 host_->native_view()->Hide(); |
| 116 } | 142 } |
| 117 | 143 |
| 118 void NativeViewHostAura::SetFocus() { | 144 void NativeViewHostAura::SetFocus() { |
| 119 aura::Window* window = host_->native_view(); | 145 aura::Window* window = host_->native_view(); |
| 120 aura::client::FocusClient* client = aura::client::GetFocusClient(window); | 146 aura::client::FocusClient* client = aura::client::GetFocusClient(window); |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 173 } else { | 199 } else { |
| 174 clipping_window_.RemoveChild(host_->native_view()); | 200 clipping_window_.RemoveChild(host_->native_view()); |
| 175 } | 201 } |
| 176 host_->native_view()->SetBounds(clipping_window_.bounds()); | 202 host_->native_view()->SetBounds(clipping_window_.bounds()); |
| 177 } | 203 } |
| 178 if (clipping_window_.parent()) | 204 if (clipping_window_.parent()) |
| 179 clipping_window_.parent()->RemoveChild(&clipping_window_); | 205 clipping_window_.parent()->RemoveChild(&clipping_window_); |
| 180 } | 206 } |
| 181 | 207 |
| 182 } // namespace views | 208 } // namespace views |
| OLD | NEW |