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

Side by Side Diff: chrome/browser/chromeos/ui/accessibility_focus_ring_controller.cc

Issue 1147323003: Made the CompositorAnimationObserver class usable (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixes Created 5 years, 6 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
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 "chrome/browser/chromeos/ui/accessibility_focus_ring_controller.h" 5 #include "chrome/browser/chromeos/ui/accessibility_focus_ring_controller.h"
6 6
7 #include "ash/display/display_controller.h" 7 #include "ash/display/display_controller.h"
8 #include "ash/shell.h" 8 #include "ash/shell.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "chrome/browser/chromeos/ui/focus_ring_layer.h" 10 #include "chrome/browser/chromeos/ui/focus_ring_layer.h"
(...skipping 25 matching lines...) Expand all
36 36
37 } // namespace 37 } // namespace
38 38
39 // static 39 // static
40 AccessibilityFocusRingController* 40 AccessibilityFocusRingController*
41 AccessibilityFocusRingController::GetInstance() { 41 AccessibilityFocusRingController::GetInstance() {
42 return Singleton<AccessibilityFocusRingController>::get(); 42 return Singleton<AccessibilityFocusRingController>::get();
43 } 43 }
44 44
45 AccessibilityFocusRingController::AccessibilityFocusRingController() 45 AccessibilityFocusRingController::AccessibilityFocusRingController()
46 : compositor_(NULL) { 46 : compositor_(nullptr) {
47 } 47 }
48 48
49 AccessibilityFocusRingController::~AccessibilityFocusRingController() { 49 AccessibilityFocusRingController::~AccessibilityFocusRingController() {
50 } 50 }
51 51
52 void AccessibilityFocusRingController::SetFocusRing( 52 void AccessibilityFocusRingController::SetFocusRing(
53 const std::vector<gfx::Rect>& rects) { 53 const std::vector<gfx::Rect>& rects) {
54 rects_ = rects; 54 rects_ = rects;
55 Update(); 55 Update();
56 } 56 }
(...skipping 16 matching lines...) Expand all
73 gfx::Rect bounds = rings_[0].GetBounds(); 73 gfx::Rect bounds = rings_[0].GetBounds();
74 gfx::Display display = 74 gfx::Display display =
75 gfx::Screen::GetNativeScreen()->GetDisplayMatching(bounds); 75 gfx::Screen::GetNativeScreen()->GetDisplayMatching(bounds);
76 aura::Window* root_window = ash::Shell::GetInstance()->display_controller() 76 aura::Window* root_window = ash::Shell::GetInstance()->display_controller()
77 ->GetRootWindowForDisplayId(display.id()); 77 ->GetRootWindowForDisplayId(display.id());
78 ui::Compositor* compositor = root_window->layer()->GetCompositor(); 78 ui::Compositor* compositor = root_window->layer()->GetCompositor();
79 if (!compositor || root_window != layers_[0]->root_window()) { 79 if (!compositor || root_window != layers_[0]->root_window()) {
80 layers_[0]->Set(rings_[0]); 80 layers_[0]->Set(rings_[0]);
81 if (compositor_ && compositor_->HasAnimationObserver(this)) { 81 if (compositor_ && compositor_->HasAnimationObserver(this)) {
82 compositor_->RemoveAnimationObserver(this); 82 compositor_->RemoveAnimationObserver(this);
83 compositor_ = NULL; 83 compositor_ = nullptr;
84 } 84 }
85 continue; 85 continue;
86 } 86 }
87 87
88 focus_change_time_ = base::TimeTicks::Now(); 88 focus_change_time_ = base::TimeTicks::Now();
89 if (!compositor->HasAnimationObserver(this)) { 89 if (!compositor->HasAnimationObserver(this)) {
90 compositor_ = compositor; 90 compositor_ = compositor;
91 compositor_->AddAnimationObserver(this); 91 compositor_->AddAnimationObserver(this);
92 } 92 }
93 } 93 }
(...skipping 208 matching lines...) Expand 10 before | Expand all | Expand 10 after
302 // focus change, so we just treat those as a delta of zero. 302 // focus change, so we just treat those as a delta of zero.
303 if (timestamp < focus_change_time_) 303 if (timestamp < focus_change_time_)
304 timestamp = focus_change_time_; 304 timestamp = focus_change_time_;
305 305
306 base::TimeDelta delta = timestamp - focus_change_time_; 306 base::TimeDelta delta = timestamp - focus_change_time_;
307 base::TimeDelta transition_time = 307 base::TimeDelta transition_time =
308 base::TimeDelta::FromMilliseconds(kTransitionTimeMilliseconds); 308 base::TimeDelta::FromMilliseconds(kTransitionTimeMilliseconds);
309 if (delta >= transition_time) { 309 if (delta >= transition_time) {
310 layers_[0]->Set(rings_[0]); 310 layers_[0]->Set(rings_[0]);
311 compositor_->RemoveAnimationObserver(this); 311 compositor_->RemoveAnimationObserver(this);
312 compositor_ = NULL; 312 compositor_ = nullptr;
313 return; 313 return;
314 } 314 }
315 315
316 double fraction = delta.InSecondsF() / transition_time.InSecondsF(); 316 double fraction = delta.InSecondsF() / transition_time.InSecondsF();
317 317
318 // Ease-in effect. 318 // Ease-in effect.
319 fraction = pow(fraction, 0.3); 319 fraction = pow(fraction, 0.3);
320 320
321 layers_[0]->Set(AccessibilityFocusRing::Interpolate( 321 layers_[0]->Set(AccessibilityFocusRing::Interpolate(
322 previous_rings_[0], rings_[0], fraction)); 322 previous_rings_[0], rings_[0], fraction));
323 } 323 }
324 324
325 void AccessibilityFocusRingController::OnCompositingShuttingDown(
326 ui::Compositor* compositor) {
xiyuan 2015/06/01 18:06:35 nit: DCHECK_EQ(compositor_, compositor);
327 if (compositor_) {
328 compositor_->RemoveAnimationObserver(this);
329 }
330 compositor_ = nullptr;
331 }
332
325 } // namespace chromeos 333 } // namespace chromeos
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/ui/accessibility_focus_ring_controller.h ('k') | ui/compositor/compositor.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698