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

Side by Side Diff: ui/views/animation/ink_drop_impl.cc

Issue 2720183002: [Views] Update ink drop for omnibox icons (Closed)
Patch Set: Nits Created 3 years, 9 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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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/animation/ink_drop_impl.h" 5 #include "ui/views/animation/ink_drop_impl.h"
6 6
7 #include "base/auto_reset.h" 7 #include "base/auto_reset.h"
8 #include "base/memory/ptr_util.h" 8 #include "base/memory/ptr_util.h"
9 #include "base/timer/timer.h" 9 #include "base/timer/timer.h"
10 #include "ui/compositor/layer.h" 10 #include "ui/compositor/layer.h"
11 #include "ui/views/animation/ink_drop_highlight.h" 11 #include "ui/views/animation/ink_drop_highlight.h"
12 #include "ui/views/animation/ink_drop_host.h" 12 #include "ui/views/animation/ink_drop_host.h"
13 #include "ui/views/animation/ink_drop_observer.h"
13 #include "ui/views/animation/square_ink_drop_ripple.h" 14 #include "ui/views/animation/square_ink_drop_ripple.h"
14 15
15 namespace views { 16 namespace views {
16 17
17 namespace { 18 namespace {
18 19
19 // The duration, in milliseconds for the highlight state fade in/out animations 20 // The duration, in milliseconds for the highlight state fade in/out animations
20 // when it is triggered by a hover changed event. 21 // when it is triggered by a hover changed event.
21 const int kHighlightFadeInOnHoverChangeDurationMs = 250; 22 const int kHighlightFadeInOnHoverChangeDurationMs = 250;
22 const int kHighlightFadeOutOnHoverChangeDurationMs = 250; 23 const int kHighlightFadeOutOnHoverChangeDurationMs = 250;
(...skipping 637 matching lines...) Expand 10 before | Expand all | Expand 10 after
660 void InkDropImpl::SetHovered(bool is_hovered) { 661 void InkDropImpl::SetHovered(bool is_hovered) {
661 is_hovered_ = is_hovered; 662 is_hovered_ = is_hovered;
662 highlight_state_->OnHoverChanged(); 663 highlight_state_->OnHoverChanged();
663 } 664 }
664 665
665 void InkDropImpl::SetFocused(bool is_focused) { 666 void InkDropImpl::SetFocused(bool is_focused) {
666 is_focused_ = is_focused; 667 is_focused_ = is_focused;
667 highlight_state_->OnFocusChanged(); 668 highlight_state_->OnFocusChanged();
668 } 669 }
669 670
671 bool InkDropImpl::IsHighlightFadingInOrVisible() const {
672 return highlight_ && highlight_->IsFadingInOrVisible();
673 }
674
670 void InkDropImpl::DestroyHiddenTargetedAnimations() { 675 void InkDropImpl::DestroyHiddenTargetedAnimations() {
671 if (ink_drop_ripple_ && 676 if (ink_drop_ripple_ &&
672 (ink_drop_ripple_->target_ink_drop_state() == InkDropState::HIDDEN || 677 (ink_drop_ripple_->target_ink_drop_state() == InkDropState::HIDDEN ||
673 ShouldAnimateToHidden(ink_drop_ripple_->target_ink_drop_state()))) { 678 ShouldAnimateToHidden(ink_drop_ripple_->target_ink_drop_state()))) {
674 DestroyInkDropRipple(); 679 DestroyInkDropRipple();
675 } 680 }
676 } 681 }
677 682
678 void InkDropImpl::CreateInkDropRipple() { 683 void InkDropImpl::CreateInkDropRipple() {
679 DCHECK(!destroying_); 684 DCHECK(!destroying_);
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after
726 } 731 }
727 } 732 }
728 733
729 void InkDropImpl::RemoveRootLayerFromHostIfNeeded() { 734 void InkDropImpl::RemoveRootLayerFromHostIfNeeded() {
730 if (root_layer_added_to_host_ && !highlight_ && !ink_drop_ripple_) { 735 if (root_layer_added_to_host_ && !highlight_ && !ink_drop_ripple_) {
731 root_layer_added_to_host_ = false; 736 root_layer_added_to_host_ = false;
732 ink_drop_host_->RemoveInkDropLayer(root_layer_.get()); 737 ink_drop_host_->RemoveInkDropLayer(root_layer_.get());
733 } 738 }
734 } 739 }
735 740
736 bool InkDropImpl::IsHighlightFadingInOrVisible() const {
737 return highlight_ && highlight_->IsFadingInOrVisible();
738 }
739
740 // ----------------------------------------------------------------------------- 741 // -----------------------------------------------------------------------------
741 // views::InkDropRippleObserver: 742 // views::InkDropRippleObserver:
742 743
743 void InkDropImpl::AnimationStarted(InkDropState ink_drop_state) { 744 void InkDropImpl::AnimationStarted(InkDropState ink_drop_state) {
744 highlight_state_->AnimationStarted(ink_drop_state); 745 highlight_state_->AnimationStarted(ink_drop_state);
746 for (InkDropObserver& observer : observers_)
747 observer.InkDropAnimationStarted();
745 } 748 }
746 749
747 void InkDropImpl::AnimationEnded(InkDropState ink_drop_state, 750 void InkDropImpl::AnimationEnded(InkDropState ink_drop_state,
748 InkDropAnimationEndedReason reason) { 751 InkDropAnimationEndedReason reason) {
749 highlight_state_->AnimationEnded(ink_drop_state, reason); 752 highlight_state_->AnimationEnded(ink_drop_state, reason);
750 if (reason != InkDropAnimationEndedReason::SUCCESS) 753 if (reason != InkDropAnimationEndedReason::SUCCESS)
751 return; 754 return;
752 // |ink_drop_ripple_| might be null during destruction. 755 // |ink_drop_ripple_| might be null during destruction.
753 if (!ink_drop_ripple_) 756 if (!ink_drop_ripple_)
754 return; 757 return;
755 if (ShouldAnimateToHidden(ink_drop_state)) { 758 if (ShouldAnimateToHidden(ink_drop_state)) {
756 ink_drop_ripple_->AnimateToState(views::InkDropState::HIDDEN); 759 ink_drop_ripple_->AnimateToState(views::InkDropState::HIDDEN);
757 } else if (ink_drop_state == views::InkDropState::HIDDEN) { 760 } else if (ink_drop_state == views::InkDropState::HIDDEN) {
758 // TODO(bruthig): Investigate whether creating and destroying 761 // TODO(bruthig): Investigate whether creating and destroying
759 // InkDropRipples is expensive and consider creating an 762 // InkDropRipples is expensive and consider creating an
760 // InkDropRipplePool. See www.crbug.com/522175. 763 // InkDropRipplePool. See www.crbug.com/522175.
761 DestroyInkDropRipple(); 764 DestroyInkDropRipple();
762 } 765 }
763 } 766 }
764 767
765 // ----------------------------------------------------------------------------- 768 // -----------------------------------------------------------------------------
766 // views::InkDropHighlightObserver: 769 // views::InkDropHighlightObserver:
767 770
768 void InkDropImpl::AnimationStarted( 771 void InkDropImpl::AnimationStarted(
769 InkDropHighlight::AnimationType animation_type) {} 772 InkDropHighlight::AnimationType animation_type) {
773 for (InkDropObserver& observer : observers_)
774 observer.InkDropAnimationStarted();
775 }
770 776
771 void InkDropImpl::AnimationEnded(InkDropHighlight::AnimationType animation_type, 777 void InkDropImpl::AnimationEnded(InkDropHighlight::AnimationType animation_type,
772 InkDropAnimationEndedReason reason) { 778 InkDropAnimationEndedReason reason) {
773 if (animation_type == InkDropHighlight::FADE_OUT && 779 if (animation_type == InkDropHighlight::FADE_OUT &&
774 reason == InkDropAnimationEndedReason::SUCCESS) { 780 reason == InkDropAnimationEndedReason::SUCCESS) {
775 DestroyInkDropHighlight(); 781 DestroyInkDropHighlight();
776 } 782 }
777 } 783 }
778 784
779 void InkDropImpl::SetHighlight(bool should_highlight, 785 void InkDropImpl::SetHighlight(bool should_highlight,
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
814 "within a call to " 820 "within a call to "
815 "HighlightState::Exit()."; 821 "HighlightState::Exit().";
816 if (highlight_state_) { 822 if (highlight_state_) {
817 base::AutoReset<bool> exit_guard(&exiting_highlight_state_, true); 823 base::AutoReset<bool> exit_guard(&exiting_highlight_state_, true);
818 highlight_state_->Exit(); 824 highlight_state_->Exit();
819 } 825 }
820 highlight_state_ = nullptr; 826 highlight_state_ = nullptr;
821 } 827 }
822 828
823 } // namespace views 829 } // namespace views
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698