Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "athena/wm/window_overview_mode.h" | 5 #include "athena/wm/window_overview_mode.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <functional> | 8 #include <functional> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 108 WindowOverviewModeImpl(aura::Window* container, | 108 WindowOverviewModeImpl(aura::Window* container, |
| 109 const WindowListProvider* window_list_provider, | 109 const WindowListProvider* window_list_provider, |
| 110 WindowOverviewModeDelegate* delegate) | 110 WindowOverviewModeDelegate* delegate) |
| 111 : container_(container), | 111 : container_(container), |
| 112 window_list_provider_(window_list_provider), | 112 window_list_provider_(window_list_provider), |
| 113 delegate_(delegate), | 113 delegate_(delegate), |
| 114 scoped_targeter_(new aura::ScopedWindowTargeter( | 114 scoped_targeter_(new aura::ScopedWindowTargeter( |
| 115 container, | 115 container, |
| 116 scoped_ptr<ui::EventTargeter>( | 116 scoped_ptr<ui::EventTargeter>( |
| 117 new StaticWindowTargeter(container)))), | 117 new StaticWindowTargeter(container)))), |
| 118 dragged_window_(NULL) { | 118 dragged_window_(NULL), |
| 119 split_({false, NULL, NULL}) { | |
| 120 CHECK(delegate_); | |
| 119 container_->set_target_handler(this); | 121 container_->set_target_handler(this); |
| 120 | 122 |
| 123 split_.enabled = delegate_->IsInSplitViewMode(&split_.left, &split_.right); | |
|
oshima
2014/08/21 22:41:00
can't you just pass SplitViewController and get st
sadrul
2014/08/28 19:10:59
Done.
| |
| 124 | |
| 121 // Prepare the desired transforms for all the windows, and set the initial | 125 // Prepare the desired transforms for all the windows, and set the initial |
| 122 // state on the windows. | 126 // state on the windows. |
| 123 ComputeTerminalStatesForAllWindows(); | 127 ComputeTerminalStatesForAllWindows(); |
| 124 SetInitialWindowStates(); | 128 SetInitialWindowStates(); |
| 125 } | 129 } |
| 126 | 130 |
| 127 virtual ~WindowOverviewModeImpl() { | 131 virtual ~WindowOverviewModeImpl() { |
| 128 container_->set_target_handler(container_->delegate()); | 132 container_->set_target_handler(container_->delegate()); |
| 129 RemoveAnimationObserver(); | 133 RemoveAnimationObserver(); |
| 130 aura::Window::Windows windows = window_list_provider_->GetWindowList(); | 134 aura::Window::Windows windows = window_list_provider_->GetWindowList(); |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 142 size_t index = 0; | 146 size_t index = 0; |
| 143 | 147 |
| 144 for (aura::Window::Windows::const_reverse_iterator iter = windows.rbegin(); | 148 for (aura::Window::Windows::const_reverse_iterator iter = windows.rbegin(); |
| 145 iter != windows.rend(); | 149 iter != windows.rend(); |
| 146 ++iter, ++index) { | 150 ++iter, ++index) { |
| 147 aura::Window* window = (*iter); | 151 aura::Window* window = (*iter); |
| 148 wm::SetShadowType(window, wm::SHADOW_TYPE_RECTANGULAR_ALWAYS_ACTIVE); | 152 wm::SetShadowType(window, wm::SHADOW_TYPE_RECTANGULAR_ALWAYS_ACTIVE); |
| 149 | 153 |
| 150 WindowOverviewState* state = new WindowOverviewState; | 154 WindowOverviewState* state = new WindowOverviewState; |
| 151 window->SetProperty(kWindowOverviewState, state); | 155 window->SetProperty(kWindowOverviewState, state); |
| 156 if (split_.enabled && (window == split_.left || window == split_.right)) { | |
| 157 // Do not let the left/right windows be scrolled. | |
| 158 int x_translate = window->bounds().width() * (1 - kMaxScale) / 2; | |
| 159 state->top.Translate(x_translate, window->bounds().height() * 0.65); | |
| 160 state->top.Scale(kMaxScale, kMaxScale); | |
| 161 state->bottom = state->top; | |
| 162 --index; | |
| 163 continue; | |
| 164 } | |
| 152 UpdateTerminalStateForWindowAtIndex(window, index, windows.size()); | 165 UpdateTerminalStateForWindowAtIndex(window, index, windows.size()); |
| 153 } | 166 } |
| 154 } | 167 } |
| 155 | 168 |
| 156 void UpdateTerminalStateForWindowAtIndex(aura::Window* window, | 169 void UpdateTerminalStateForWindowAtIndex(aura::Window* window, |
| 157 size_t index, | 170 size_t index, |
| 158 size_t window_count) { | 171 size_t window_count) { |
| 159 const int kGapBetweenWindowsBottom = 10; | 172 const int kGapBetweenWindowsBottom = 10; |
| 160 const int kGapBetweenWindowsTop = 5; | 173 const int kGapBetweenWindowsTop = 5; |
| 161 | 174 |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 178 WindowOverviewState* state = window->GetProperty(kWindowOverviewState); | 191 WindowOverviewState* state = window->GetProperty(kWindowOverviewState); |
| 179 CHECK(state); | 192 CHECK(state); |
| 180 state->top = top_transform; | 193 state->top = top_transform; |
| 181 state->bottom = bottom_transform; | 194 state->bottom = bottom_transform; |
| 182 state->progress = 0.f; | 195 state->progress = 0.f; |
| 183 } | 196 } |
| 184 | 197 |
| 185 // Sets the initial position for the windows for the overview mode. | 198 // Sets the initial position for the windows for the overview mode. |
| 186 void SetInitialWindowStates() { | 199 void SetInitialWindowStates() { |
| 187 aura::Window::Windows windows = window_list_provider_->GetWindowList(); | 200 aura::Window::Windows windows = window_list_provider_->GetWindowList(); |
| 188 size_t window_count = windows.size(); | |
| 189 // The initial overview state of the topmost three windows. | 201 // The initial overview state of the topmost three windows. |
| 190 const float kInitialProgress[] = { 0.5f, 0.05f, 0.01f }; | 202 const float kInitialProgress[] = { 0.5f, 0.05f, 0.01f }; |
| 191 for (size_t i = 0; i < window_count; ++i) { | 203 size_t index = 0; |
| 204 for (aura::Window::Windows::const_reverse_iterator iter = windows.rbegin(); | |
| 205 iter != windows.rend(); | |
| 206 ++iter) { | |
| 192 float progress = 0.f; | 207 float progress = 0.f; |
| 193 aura::Window* window = windows[window_count - 1 - i]; | 208 aura::Window* window = *iter; |
| 194 if (i < arraysize(kInitialProgress)) | 209 if (split_.enabled && (window == split_.left || window == split_.right)) { |
| 195 progress = kInitialProgress[i]; | 210 progress = 1; |
| 211 } else { | |
| 212 if (index < arraysize(kInitialProgress)) | |
| 213 progress = kInitialProgress[index]; | |
| 214 ++index; | |
| 215 } | |
| 196 | 216 |
| 197 scoped_refptr<ui::LayerAnimator> animator = | 217 scoped_refptr<ui::LayerAnimator> animator = |
| 198 window->layer()->GetAnimator(); | 218 window->layer()->GetAnimator(); |
| 199 | 219 |
| 200 // Unset any in-progress animation. | 220 // Unset any in-progress animation. |
| 201 animator->AbortAllAnimations(); | 221 animator->AbortAllAnimations(); |
| 202 window->Show(); | 222 window->Show(); |
| 203 window->SetTransform(gfx::Transform()); | 223 window->SetTransform(gfx::Transform()); |
| 204 // Setup the animation. | 224 // Setup the animation. |
| 205 { | 225 { |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 266 // |delta_y_p| for the next window. | 286 // |delta_y_p| for the next window. |
| 267 SetWindowProgress(window, std::min(1.f, state->progress + delta_y_p)); | 287 SetWindowProgress(window, std::min(1.f, state->progress + delta_y_p)); |
| 268 delta_y_p /= 2.f; | 288 delta_y_p /= 2.f; |
| 269 } | 289 } |
| 270 } | 290 } |
| 271 } | 291 } |
| 272 } | 292 } |
| 273 | 293 |
| 274 int GetScrollableHeight() const { | 294 int GetScrollableHeight() const { |
| 275 const float kScrollableFraction = 0.65f; | 295 const float kScrollableFraction = 0.65f; |
| 276 return container_->bounds().height() * kScrollableFraction; | 296 const float kScrollableFractionInSplit = 0.5f; |
| 297 const float fraction = | |
| 298 split_.enabled ? kScrollableFractionInSplit : kScrollableFraction; | |
| 299 return container_->bounds().height() * fraction; | |
| 277 } | 300 } |
| 278 | 301 |
| 279 void CreateFlingerFor(const ui::GestureEvent& event) { | 302 void CreateFlingerFor(const ui::GestureEvent& event) { |
| 280 gfx::Vector2dF velocity(event.details().velocity_x(), | 303 gfx::Vector2dF velocity(event.details().velocity_x(), |
| 281 event.details().velocity_y()); | 304 event.details().velocity_y()); |
| 282 fling_.reset(new ui::FlingCurve(velocity, gfx::FrameTime::Now())); | 305 fling_.reset(new ui::FlingCurve(velocity, gfx::FrameTime::Now())); |
| 283 } | 306 } |
| 284 | 307 |
| 285 void AddAnimationObserver() { | 308 void AddAnimationObserver() { |
| 286 ui::Compositor* compositor = container_->GetHost()->compositor(); | 309 ui::Compositor* compositor = container_->GetHost()->compositor(); |
| (...skipping 147 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 434 OverviewToolbar::ActionType action = overview_toolbar_->current_action(); | 457 OverviewToolbar::ActionType action = overview_toolbar_->current_action(); |
| 435 overview_toolbar_.reset(); | 458 overview_toolbar_.reset(); |
| 436 if (action == OverviewToolbar::ACTION_TYPE_SPLIT) | 459 if (action == OverviewToolbar::ACTION_TYPE_SPLIT) |
| 437 delegate_->OnSplitViewMode(NULL, dragged_window_); | 460 delegate_->OnSplitViewMode(NULL, dragged_window_); |
| 438 else if (ShouldCloseDragWindow(gesture)) | 461 else if (ShouldCloseDragWindow(gesture)) |
| 439 CloseDragWindow(gesture); | 462 CloseDragWindow(gesture); |
| 440 else | 463 else |
| 441 RestoreDragWindow(); | 464 RestoreDragWindow(); |
| 442 } | 465 } |
| 443 | 466 |
| 467 void SelectWindow(aura::Window* window) { | |
| 468 if (!split_.enabled) { | |
| 469 delegate_->OnSelectWindow(window); | |
| 470 } else { | |
| 471 // If the selected window is one of the left/right windows, then keep the | |
| 472 // current state. | |
| 473 if (window == split_.left || window == split_.right) { | |
| 474 delegate_->OnSplitViewMode(split_.left, split_.right); | |
| 475 } else { | |
| 476 delegate_->OnSelectWindow(window); | |
| 477 } | |
| 478 } | |
| 479 } | |
| 480 | |
| 444 // ui::EventHandler: | 481 // ui::EventHandler: |
| 445 virtual void OnMouseEvent(ui::MouseEvent* mouse) OVERRIDE { | 482 virtual void OnMouseEvent(ui::MouseEvent* mouse) OVERRIDE { |
| 446 if (mouse->type() == ui::ET_MOUSE_PRESSED) { | 483 if (mouse->type() == ui::ET_MOUSE_PRESSED) { |
| 447 aura::Window* select = SelectWindowAt(mouse); | 484 aura::Window* select = SelectWindowAt(mouse); |
| 448 if (select) { | 485 if (select) { |
| 449 mouse->SetHandled(); | 486 mouse->SetHandled(); |
| 450 delegate_->OnSelectWindow(select); | 487 SelectWindow(select); |
| 451 } | 488 } |
| 452 } else if (mouse->type() == ui::ET_MOUSEWHEEL) { | 489 } else if (mouse->type() == ui::ET_MOUSEWHEEL) { |
| 453 DoScroll(static_cast<ui::MouseWheelEvent*>(mouse)->y_offset()); | 490 DoScroll(static_cast<ui::MouseWheelEvent*>(mouse)->y_offset()); |
| 454 } | 491 } |
| 455 } | 492 } |
| 456 | 493 |
| 457 virtual void OnScrollEvent(ui::ScrollEvent* scroll) OVERRIDE { | 494 virtual void OnScrollEvent(ui::ScrollEvent* scroll) OVERRIDE { |
| 458 if (scroll->type() == ui::ET_SCROLL) | 495 if (scroll->type() == ui::ET_SCROLL) |
| 459 DoScroll(scroll->y_offset()); | 496 DoScroll(scroll->y_offset()); |
| 460 } | 497 } |
| 461 | 498 |
| 462 virtual void OnGestureEvent(ui::GestureEvent* gesture) OVERRIDE { | 499 virtual void OnGestureEvent(ui::GestureEvent* gesture) OVERRIDE { |
| 463 if (gesture->type() == ui::ET_GESTURE_TAP) { | 500 if (gesture->type() == ui::ET_GESTURE_TAP) { |
| 464 aura::Window* select = SelectWindowAt(gesture); | 501 aura::Window* select = SelectWindowAt(gesture); |
| 465 if (select) { | 502 if (select) { |
| 466 gesture->SetHandled(); | 503 gesture->SetHandled(); |
| 467 delegate_->OnSelectWindow(select); | 504 SelectWindow(select); |
| 468 } | 505 } |
| 469 } else if (gesture->type() == ui::ET_GESTURE_SCROLL_BEGIN) { | 506 } else if (gesture->type() == ui::ET_GESTURE_SCROLL_BEGIN) { |
| 470 if (std::abs(gesture->details().scroll_x_hint()) > | 507 if (std::abs(gesture->details().scroll_x_hint()) > |
| 471 std::abs(gesture->details().scroll_y_hint()) * 2) { | 508 std::abs(gesture->details().scroll_y_hint()) * 2) { |
| 472 dragged_start_location_ = gesture->location(); | 509 dragged_start_location_ = gesture->location(); |
| 473 dragged_window_ = SelectWindowAt(gesture); | 510 dragged_window_ = SelectWindowAt(gesture); |
| 474 if (dragged_window_) | 511 if (dragged_window_) |
| 475 overview_toolbar_.reset(new OverviewToolbar(container_)); | 512 overview_toolbar_.reset(new OverviewToolbar(container_)); |
| 476 } | 513 } |
| 477 } else if (gesture->type() == ui::ET_GESTURE_SCROLL_UPDATE) { | 514 } else if (gesture->type() == ui::ET_GESTURE_SCROLL_UPDATE) { |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 511 if (scroll.IsZero()) { | 548 if (scroll.IsZero()) { |
| 512 fling_.reset(); | 549 fling_.reset(); |
| 513 RemoveAnimationObserver(); | 550 RemoveAnimationObserver(); |
| 514 } else { | 551 } else { |
| 515 DoScroll(scroll.y()); | 552 DoScroll(scroll.y()); |
| 516 } | 553 } |
| 517 } | 554 } |
| 518 | 555 |
| 519 const int kMinDistanceForDismissal = 300; | 556 const int kMinDistanceForDismissal = 300; |
| 520 const float kMinScale = 0.6f; | 557 const float kMinScale = 0.6f; |
| 521 const float kMaxScale = 0.95f; | 558 const float kMaxScale = 0.75f; |
| 522 const float kMaxOpacity = 1.0f; | 559 const float kMaxOpacity = 1.0f; |
| 523 const float kMinOpacity = 0.2f; | 560 const float kMinOpacity = 0.2f; |
| 524 | 561 |
| 525 aura::Window* container_; | 562 aura::Window* container_; |
| 526 // Provider of the stack of windows to show in the overview mode. Not owned. | 563 // Provider of the stack of windows to show in the overview mode. Not owned. |
| 527 const WindowListProvider* window_list_provider_; | 564 const WindowListProvider* window_list_provider_; |
| 528 WindowOverviewModeDelegate* delegate_; | 565 WindowOverviewModeDelegate* delegate_; |
| 529 scoped_ptr<aura::ScopedWindowTargeter> scoped_targeter_; | 566 scoped_ptr<aura::ScopedWindowTargeter> scoped_targeter_; |
| 530 scoped_ptr<ui::FlingCurve> fling_; | 567 scoped_ptr<ui::FlingCurve> fling_; |
| 531 | 568 |
| 532 aura::Window* dragged_window_; | 569 aura::Window* dragged_window_; |
| 533 gfx::Point dragged_start_location_; | 570 gfx::Point dragged_start_location_; |
| 534 scoped_ptr<OverviewToolbar> overview_toolbar_; | 571 scoped_ptr<OverviewToolbar> overview_toolbar_; |
| 535 | 572 |
| 573 struct { | |
| 574 bool enabled; | |
| 575 aura::Window* left; | |
| 576 aura::Window* right; | |
| 577 } split_; | |
| 578 | |
| 536 DISALLOW_COPY_AND_ASSIGN(WindowOverviewModeImpl); | 579 DISALLOW_COPY_AND_ASSIGN(WindowOverviewModeImpl); |
| 537 }; | 580 }; |
| 538 | 581 |
| 539 } // namespace | 582 } // namespace |
| 540 | 583 |
| 541 // static | 584 // static |
| 542 scoped_ptr<WindowOverviewMode> WindowOverviewMode::Create( | 585 scoped_ptr<WindowOverviewMode> WindowOverviewMode::Create( |
| 543 aura::Window* container, | 586 aura::Window* container, |
| 544 const WindowListProvider* window_list_provider, | 587 const WindowListProvider* window_list_provider, |
| 545 WindowOverviewModeDelegate* delegate) { | 588 WindowOverviewModeDelegate* delegate) { |
| 546 return scoped_ptr<WindowOverviewMode>( | 589 return scoped_ptr<WindowOverviewMode>( |
| 547 new WindowOverviewModeImpl(container, window_list_provider, delegate)); | 590 new WindowOverviewModeImpl(container, window_list_provider, delegate)); |
| 548 } | 591 } |
| 549 | 592 |
| 550 } // namespace athena | 593 } // namespace athena |
| OLD | NEW |