| OLD | NEW |
| 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_animation_controller_factory.h" | 5 #include "ui/views/animation/ink_drop_animation_controller_factory.h" |
| 6 | 6 |
| 7 #include "ui/base/resource/material_design/material_design_controller.h" | 7 #include "ui/base/resource/material_design/material_design_controller.h" |
| 8 #include "ui/gfx/geometry/rect.h" | 8 #include "ui/gfx/geometry/rect.h" |
| 9 #include "ui/gfx/geometry/size.h" | 9 #include "ui/gfx/geometry/size.h" |
| 10 #include "ui/views/animation/ink_drop_animation_controller.h" | 10 #include "ui/views/animation/ink_drop_animation_controller.h" |
| 11 #include "ui/views/animation/ink_drop_animation_controller_impl.h" | 11 #include "ui/views/animation/ink_drop_animation_controller_impl.h" |
| 12 #include "ui/views/views_export.h" | 12 #include "ui/views/views_export.h" |
| 13 | 13 |
| 14 namespace views { | 14 namespace views { |
| 15 | 15 |
| 16 namespace { | 16 namespace { |
| 17 | 17 |
| 18 // A stub implementation of an InkDropAnimationController that can be used when | 18 // A stub implementation of an InkDropAnimationController that can be used when |
| 19 // material design is not enabled. | 19 // material design is not enabled. |
| 20 class InkDropAnimationControllerStub | 20 class InkDropAnimationControllerStub |
| 21 : public InkDropAnimationController { | 21 : public InkDropAnimationController { |
| 22 public: | 22 public: |
| 23 explicit InkDropAnimationControllerStub(InkDropHost* ink_drop_host); | 23 explicit InkDropAnimationControllerStub(); |
| 24 ~InkDropAnimationControllerStub() override; | 24 ~InkDropAnimationControllerStub() override; |
| 25 | 25 |
| 26 // InkDropAnimationController: | 26 // InkDropAnimationController: |
| 27 InkDropState GetInkDropState() const override; |
| 27 void AnimateToState(InkDropState state) override; | 28 void AnimateToState(InkDropState state) override; |
| 28 void SetInkDropSize(const gfx::Size& size) override; | 29 gfx::Size GetInkDropLargeSize() const override; |
| 29 gfx::Rect GetInkDropBounds() const override; | 30 void SetInkDropSize(const gfx::Size& large_size, |
| 30 void SetInkDropBounds(const gfx::Rect& bounds) override; | 31 int large_corner_radius, |
| 32 const gfx::Size& small_size, |
| 33 int small_corner_radius) override; |
| 34 void SetInkDropCenter(const gfx::Point& center_point) override; |
| 31 | 35 |
| 32 private: | 36 private: |
| 33 // The bounds of the ink drop layers. Defined in the coordinate space of the | |
| 34 // parent ui::Layer that the ink drop layers were added to. | |
| 35 gfx::Rect ink_drop_bounds_; | |
| 36 | |
| 37 DISALLOW_COPY_AND_ASSIGN(InkDropAnimationControllerStub); | 37 DISALLOW_COPY_AND_ASSIGN(InkDropAnimationControllerStub); |
| 38 }; | 38 }; |
| 39 | 39 |
| 40 InkDropAnimationControllerStub::InkDropAnimationControllerStub( | 40 InkDropAnimationControllerStub::InkDropAnimationControllerStub() {} |
| 41 InkDropHost* ink_drop_host) {} | |
| 42 | 41 |
| 43 InkDropAnimationControllerStub::~InkDropAnimationControllerStub() {} | 42 InkDropAnimationControllerStub::~InkDropAnimationControllerStub() {} |
| 44 | 43 |
| 44 InkDropState InkDropAnimationControllerStub::GetInkDropState() const { |
| 45 return InkDropState::HIDDEN; |
| 46 } |
| 47 |
| 45 void InkDropAnimationControllerStub::AnimateToState(InkDropState state) {} | 48 void InkDropAnimationControllerStub::AnimateToState(InkDropState state) {} |
| 46 | 49 |
| 47 void InkDropAnimationControllerStub::SetInkDropSize(const gfx::Size& size) { | 50 gfx::Size InkDropAnimationControllerStub::GetInkDropLargeSize() const { |
| 48 ink_drop_bounds_.set_size(size); | 51 return gfx::Size(); |
| 49 } | 52 } |
| 50 | 53 |
| 51 gfx::Rect InkDropAnimationControllerStub::GetInkDropBounds() const { | 54 void InkDropAnimationControllerStub::SetInkDropSize(const gfx::Size& large_size, |
| 52 return ink_drop_bounds_; | 55 int large_corner_radius, |
| 53 } | 56 const gfx::Size& small_size, |
| 57 int small_corner_radius) {} |
| 54 | 58 |
| 55 void InkDropAnimationControllerStub::SetInkDropBounds(const gfx::Rect& bounds) { | 59 void InkDropAnimationControllerStub::SetInkDropCenter( |
| 56 ink_drop_bounds_ = bounds; | 60 const gfx::Point& center_point) {} |
| 57 } | |
| 58 | 61 |
| 59 } // namespace | 62 } // namespace |
| 60 | 63 |
| 61 InkDropAnimationControllerFactory::InkDropAnimationControllerFactory() {} | 64 InkDropAnimationControllerFactory::InkDropAnimationControllerFactory() {} |
| 62 | 65 |
| 63 InkDropAnimationControllerFactory::~InkDropAnimationControllerFactory() {} | 66 InkDropAnimationControllerFactory::~InkDropAnimationControllerFactory() {} |
| 64 | 67 |
| 65 scoped_ptr<InkDropAnimationController> | 68 scoped_ptr<InkDropAnimationController> |
| 66 InkDropAnimationControllerFactory::CreateInkDropAnimationController( | 69 InkDropAnimationControllerFactory::CreateInkDropAnimationController( |
| 67 InkDropHost* ink_drop_host) { | 70 InkDropHost* ink_drop_host) { |
| 68 #if defined(OS_CHROMEOS) | 71 #if defined(OS_CHROMEOS) |
| 72 // The ink drop animation is only targeted at ChromeOS because there is |
| 73 // concern it will conflict with OS level touch feedback in a bad way. |
| 69 if (ui::MaterialDesignController::IsModeMaterial()) { | 74 if (ui::MaterialDesignController::IsModeMaterial()) { |
| 70 return scoped_ptr<InkDropAnimationController>( | 75 return scoped_ptr<InkDropAnimationController>( |
| 71 new InkDropAnimationControllerImpl(ink_drop_host)); | 76 new InkDropAnimationControllerImpl(ink_drop_host)); |
| 72 } else { | 77 } else { |
| 73 return scoped_ptr<InkDropAnimationController>( | 78 return scoped_ptr<InkDropAnimationController>( |
| 74 new InkDropAnimationControllerStub(ink_drop_host)); | 79 new InkDropAnimationControllerStub()); |
| 75 } | 80 } |
| 76 #endif // defined(OS_CHROMEOS) | 81 #endif // defined(OS_CHROMEOS) |
| 77 | 82 |
| 78 return scoped_ptr<InkDropAnimationController>( | 83 return scoped_ptr<InkDropAnimationController>( |
| 79 new InkDropAnimationControllerStub(ink_drop_host)); | 84 new InkDropAnimationControllerStub()); |
| 80 } | 85 } |
| 81 | 86 |
| 82 } // namespace views | 87 } // namespace views |
| OLD | NEW |