| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/aura/window.h" | 5 #include "ui/aura/window.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/stl_util.h" | 10 #include "base/stl_util.h" |
| (...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 96 UpdateLayerName(name_); | 96 UpdateLayerName(name_); |
| 97 } | 97 } |
| 98 | 98 |
| 99 void Window::Show() { | 99 void Window::Show() { |
| 100 SetVisible(true); | 100 SetVisible(true); |
| 101 } | 101 } |
| 102 | 102 |
| 103 void Window::Hide() { | 103 void Window::Hide() { |
| 104 SetVisible(false); | 104 SetVisible(false); |
| 105 ReleaseCapture(); | 105 ReleaseCapture(); |
| 106 if (RootWindow::GetInstance()->active_window() == this || | |
| 107 !RootWindow::GetInstance()->active_window()) { | |
| 108 RootWindow::GetInstance()->ActivateTopmostWindow(); | |
| 109 } | |
| 110 } | 106 } |
| 111 | 107 |
| 112 bool Window::IsVisible() const { | 108 bool Window::IsVisible() const { |
| 113 return layer_->IsDrawn(); | 109 return layer_->IsDrawn(); |
| 114 } | 110 } |
| 115 | 111 |
| 116 gfx::Rect Window::GetScreenBounds() const { | 112 gfx::Rect Window::GetScreenBounds() const { |
| 117 gfx::Point origin = bounds().origin(); | 113 gfx::Point origin = bounds().origin(); |
| 118 Window::ConvertPointToWindow(parent_, | 114 Window::ConvertPointToWindow(parent_, |
| 119 aura::RootWindow::GetInstance(), | 115 aura::RootWindow::GetInstance(), |
| 120 &origin); | 116 &origin); |
| 121 return gfx::Rect(origin, bounds().size()); | 117 return gfx::Rect(origin, bounds().size()); |
| 122 } | 118 } |
| 123 | 119 |
| 124 void Window::Activate() { | |
| 125 // If we support minimization need to ensure this restores the window first. | |
| 126 aura::RootWindow::GetInstance()->SetActiveWindow(this, this); | |
| 127 } | |
| 128 | |
| 129 void Window::Deactivate() { | |
| 130 aura::RootWindow::GetInstance()->Deactivate(this); | |
| 131 } | |
| 132 | |
| 133 bool Window::IsActive() const { | |
| 134 return aura::RootWindow::GetInstance()->active_window() == this; | |
| 135 } | |
| 136 | |
| 137 void Window::SetTransform(const ui::Transform& transform) { | 120 void Window::SetTransform(const ui::Transform& transform) { |
| 138 layer()->SetTransform(transform); | 121 layer()->SetTransform(transform); |
| 139 } | 122 } |
| 140 | 123 |
| 141 void Window::SetLayoutManager(LayoutManager* layout_manager) { | 124 void Window::SetLayoutManager(LayoutManager* layout_manager) { |
| 142 layout_manager_.reset(layout_manager); | 125 layout_manager_.reset(layout_manager); |
| 143 } | 126 } |
| 144 | 127 |
| 145 void Window::SetBounds(const gfx::Rect& new_bounds) { | 128 void Window::SetBounds(const gfx::Rect& new_bounds) { |
| 146 if (parent_ && parent_->layout_manager()) | 129 if (parent_ && parent_->layout_manager()) |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 212 Window* transient_child = *i; | 195 Window* transient_child = *i; |
| 213 if (transient_child->parent_ == this) { | 196 if (transient_child->parent_ == this) { |
| 214 StackChildAbove(transient_child, last_transient); | 197 StackChildAbove(transient_child, last_transient); |
| 215 last_transient = transient_child; | 198 last_transient = transient_child; |
| 216 } | 199 } |
| 217 } | 200 } |
| 218 | 201 |
| 219 child->OnStackingChanged(); | 202 child->OnStackingChanged(); |
| 220 } | 203 } |
| 221 | 204 |
| 222 bool Window::CanActivate() const { | |
| 223 return IsVisible() && (!delegate_ || delegate_->ShouldActivate(NULL)); | |
| 224 } | |
| 225 | |
| 226 void Window::AddChild(Window* child) { | 205 void Window::AddChild(Window* child) { |
| 227 DCHECK(std::find(children_.begin(), children_.end(), child) == | 206 DCHECK(std::find(children_.begin(), children_.end(), child) == |
| 228 children_.end()); | 207 children_.end()); |
| 229 if (child->parent()) | 208 if (child->parent()) |
| 230 child->parent()->RemoveChild(child); | 209 child->parent()->RemoveChild(child); |
| 231 child->parent_ = this; | 210 child->parent_ = this; |
| 232 | 211 |
| 233 layer_->Add(child->layer_.get()); | 212 layer_->Add(child->layer_.get()); |
| 234 | 213 |
| 235 children_.push_back(child); | 214 children_.push_back(child); |
| (...skipping 329 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 565 if (id_ != -1) { | 544 if (id_ != -1) { |
| 566 char id_buf[10]; | 545 char id_buf[10]; |
| 567 base::snprintf(id_buf, sizeof(id_buf), " %d", id_); | 546 base::snprintf(id_buf, sizeof(id_buf), " %d", id_); |
| 568 layer_name.append(id_buf); | 547 layer_name.append(id_buf); |
| 569 } | 548 } |
| 570 layer()->set_name(layer_name); | 549 layer()->set_name(layer_name); |
| 571 #endif | 550 #endif |
| 572 } | 551 } |
| 573 | 552 |
| 574 } // namespace aura | 553 } // namespace aura |
| OLD | NEW |