Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(804)

Side by Side Diff: athena/wm/window_manager_impl.cc

Issue 546123002: Ensure that an activity is activated when overview mode is exited (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « athena/wm/window_manager_impl.h ('k') | athena/wm/window_manager_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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_manager_impl.h" 5 #include "athena/wm/window_manager_impl.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "athena/common/container_priorities.h" 9 #include "athena/common/container_priorities.h"
10 #include "athena/screen/public/screen_manager.h" 10 #include "athena/screen/public/screen_manager.h"
(...skipping 175 matching lines...) Expand 10 before | Expand all | Expand 10 after
186 186
187 // Re-stack all windows in the order defined by window_list_provider_. 187 // Re-stack all windows in the order defined by window_list_provider_.
188 aura::Window::Windows window_list = window_list_provider_->GetWindowList(); 188 aura::Window::Windows window_list = window_list_provider_->GetWindowList();
189 aura::Window::Windows::iterator it; 189 aura::Window::Windows::iterator it;
190 for (it = window_list.begin(); it != window_list.end(); ++it) 190 for (it = window_list.begin(); it != window_list.end(); ++it)
191 container_->StackChildAtTop(*it); 191 container_->StackChildAtTop(*it);
192 overview_ = WindowOverviewMode::Create( 192 overview_ = WindowOverviewMode::Create(
193 container_.get(), window_list_provider_.get(), 193 container_.get(), window_list_provider_.get(),
194 split_view_controller_.get(), this); 194 split_view_controller_.get(), this);
195 } else { 195 } else {
196 overview_.reset(); 196 // Deleting the WindowOverviewMode object may call back to SetInOverview().
197 // Clear |overview_| first, then delete the object.
198 WindowOverviewMode* to_delete = overview_.release();
199 delete to_delete;
200
197 FOR_EACH_OBSERVER(WindowManagerObserver, observers_, OnOverviewModeExit()); 201 FOR_EACH_OBSERVER(WindowManagerObserver, observers_, OnOverviewModeExit());
198 } 202 }
199 } 203 }
200 204
201 void WindowManagerImpl::InstallAccelerators() { 205 void WindowManagerImpl::InstallAccelerators() {
202 const AcceleratorData accelerator_data[] = { 206 const AcceleratorData accelerator_data[] = {
203 {TRIGGER_ON_PRESS, ui::VKEY_F6, ui::EF_NONE, CMD_TOGGLE_OVERVIEW, 207 {TRIGGER_ON_PRESS, ui::VKEY_F6, ui::EF_NONE, CMD_TOGGLE_OVERVIEW,
204 AF_NONE}, 208 AF_NONE},
205 {TRIGGER_ON_PRESS, ui::VKEY_F6, ui::EF_CONTROL_DOWN, 209 {TRIGGER_ON_PRESS, ui::VKEY_F6, ui::EF_CONTROL_DOWN,
206 CMD_TOGGLE_SPLIT_VIEW, AF_NONE}, 210 CMD_TOGGLE_SPLIT_VIEW, AF_NONE},
207 }; 211 };
208 AcceleratorManager::Get()->RegisterAccelerators( 212 AcceleratorManager::Get()->RegisterAccelerators(
209 accelerator_data, arraysize(accelerator_data), this); 213 accelerator_data, arraysize(accelerator_data), this);
210 } 214 }
211 215
212 void WindowManagerImpl::AddObserver(WindowManagerObserver* observer) { 216 void WindowManagerImpl::AddObserver(WindowManagerObserver* observer) {
213 observers_.AddObserver(observer); 217 observers_.AddObserver(observer);
214 } 218 }
215 219
216 void WindowManagerImpl::RemoveObserver(WindowManagerObserver* observer) { 220 void WindowManagerImpl::RemoveObserver(WindowManagerObserver* observer) {
217 observers_.RemoveObserver(observer); 221 observers_.RemoveObserver(observer);
218 } 222 }
219 223
220 void WindowManagerImpl::ToggleSplitViewForTest() { 224 void WindowManagerImpl::ToggleSplitViewForTest() {
221 ToggleSplitview(); 225 ToggleSplitview();
222 } 226 }
223 227
224 void WindowManagerImpl::OnSelectWindow(aura::Window* window) { 228 void WindowManagerImpl::OnSelectWindow(aura::Window* window,
229 SplitType split_type) {
230 SetInOverview(false);
231 window->layer()->SetOpacity(1.0f);
232 window->Show();
233 wm::ActivateWindow(window);
234
235 if (split_type != SPLIT_NONE) {
236 FOR_EACH_OBSERVER(WindowManagerObserver,
237 observers_,
238 OnSplitViewModeEnter());
239 if (split_type == SPLIT_LEFT)
240 split_view_controller_->ActivateSplitMode(window, NULL);
241 else
242 split_view_controller_->ActivateSplitMode(NULL, window);
243 return;
244 }
245
225 if (split_view_controller_->IsSplitViewModeActive()) { 246 if (split_view_controller_->IsSplitViewModeActive()) {
226 split_view_controller_->DeactivateSplitMode(); 247 split_view_controller_->DeactivateSplitMode();
pkotwicz 2014/09/05 22:02:07 This ends up hiding the windows in split view imme
227 FOR_EACH_OBSERVER(WindowManagerObserver, observers_, OnSplitViewModeExit()); 248 FOR_EACH_OBSERVER(WindowManagerObserver, observers_, OnSplitViewModeExit());
228 } 249 }
229 wm::ActivateWindow(window); 250
230 SetInOverview(false);
231 // If |window| does not have the size of the work-area, then make sure it is 251 // If |window| does not have the size of the work-area, then make sure it is
232 // resized. 252 // resized.
233 const gfx::Size work_area = 253 const gfx::Size work_area =
234 gfx::Screen::GetNativeScreen()->GetPrimaryDisplay().work_area().size(); 254 gfx::Screen::GetNativeScreen()->GetPrimaryDisplay().work_area().size();
235 if (window->GetTargetBounds().size() != work_area) { 255 if (window->GetTargetBounds().size() != work_area) {
236 const gfx::Rect& window_bounds = window->bounds(); 256 const gfx::Rect& window_bounds = window->bounds();
237 const gfx::Rect desired_bounds(work_area); 257 const gfx::Rect desired_bounds(work_area);
238 gfx::Transform transform; 258 gfx::Transform transform;
239 transform.Translate(desired_bounds.x() - window_bounds.x(), 259 transform.Translate(desired_bounds.x() - window_bounds.x(),
240 desired_bounds.y() - window_bounds.y()); 260 desired_bounds.y() - window_bounds.y());
241 transform.Scale(desired_bounds.width() / window_bounds.width(), 261 transform.Scale(desired_bounds.width() / window_bounds.width(),
242 desired_bounds.height() / window_bounds.height()); 262 desired_bounds.height() / window_bounds.height());
243 window->layer()->GetAnimator()->AbortAllAnimations();
244 ui::ScopedLayerAnimationSettings settings(window->layer()->GetAnimator()); 263 ui::ScopedLayerAnimationSettings settings(window->layer()->GetAnimator());
245 settings.SetPreemptionStrategy( 264 settings.SetPreemptionStrategy(
246 ui::LayerAnimator::IMMEDIATELY_ANIMATE_TO_NEW_TARGET); 265 ui::LayerAnimator::IMMEDIATELY_ANIMATE_TO_NEW_TARGET);
247 settings.AddObserver( 266 settings.AddObserver(
248 new ui::ClosureAnimationObserver(base::Bind(&SetWindowState, 267 new ui::ClosureAnimationObserver(base::Bind(&SetWindowState,
249 base::Unretained(window), 268 base::Unretained(window),
250 desired_bounds, 269 desired_bounds,
251 gfx::Transform()))); 270 gfx::Transform())));
252 window->SetTransform(transform); 271 window->SetTransform(transform);
253 } 272 }
254 } 273 }
255 274
256 void WindowManagerImpl::OnSplitViewMode(aura::Window* left,
257 aura::Window* right) {
258 SetInOverview(false);
259 FOR_EACH_OBSERVER(WindowManagerObserver, observers_, OnSplitViewModeEnter());
260 split_view_controller_->ActivateSplitMode(left, right);
261 }
262
263 void WindowManagerImpl::OnWindowAdded(aura::Window* new_window) { 275 void WindowManagerImpl::OnWindowAdded(aura::Window* new_window) {
264 // TODO(oshima): Creating a new window should updates the ovewview mode 276 // TODO(oshima): Creating a new window should updates the ovewview mode
265 // instead of exitting. 277 // instead of exitting.
266 if (new_window->type() == ui::wm::WINDOW_TYPE_NORMAL) 278 if (new_window->type() == ui::wm::WINDOW_TYPE_NORMAL)
267 SetInOverview(false); 279 SetInOverview(false);
268 } 280 }
269 281
270 void WindowManagerImpl::OnWindowDestroying(aura::Window* window) { 282 void WindowManagerImpl::OnWindowDestroying(aura::Window* window) {
271 if (window == container_) 283 if (window == container_)
272 container_.reset(); 284 container_.reset();
(...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after
401 DCHECK(!instance); 413 DCHECK(!instance);
402 } 414 }
403 415
404 // static 416 // static
405 WindowManager* WindowManager::GetInstance() { 417 WindowManager* WindowManager::GetInstance() {
406 DCHECK(instance); 418 DCHECK(instance);
407 return instance; 419 return instance;
408 } 420 }
409 421
410 } // namespace athena 422 } // namespace athena
OLDNEW
« no previous file with comments | « athena/wm/window_manager_impl.h ('k') | athena/wm/window_manager_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698