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

Unified Diff: ui/views/animation/toolbar_ink_drop_delegate.cc

Issue 1411833006: Refactoring to make adding ink drop animations easier (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Attempt to refactor ink drop animations Created 5 years, 1 month 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 side-by-side diff with in-line comments
Download patch
Index: ui/views/animation/toolbar_ink_drop_delegate.cc
diff --git a/ui/views/animation/toolbar_ink_drop_delegate.cc b/ui/views/animation/toolbar_ink_drop_delegate.cc
new file mode 100644
index 0000000000000000000000000000000000000000..66a098ab89d62743b49ab1d90c2a19d5e400de35
--- /dev/null
+++ b/ui/views/animation/toolbar_ink_drop_delegate.cc
@@ -0,0 +1,60 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ui/events/event.h"
+#include "ui/views/animation/ink_drop_animation_controller.h"
+#include "ui/views/animation/ink_drop_state.h"
+#include "ui/views/animation/toolbar_ink_drop_delegate.h"
+
+namespace views {
+
+ToolbarInkDropDelegate::ToolbarInkDropDelegate(
+ InkDropAnimationController* ink_drop_animation_controller)
+ : ink_drop_animation_controller_(ink_drop_animation_controller) {
+}
+
+ToolbarInkDropDelegate::~ToolbarInkDropDelegate() {
+}
+
+void ToolbarInkDropDelegate::OnGestureEvent(ui::GestureEvent* event) {
bruthig 2015/11/06 20:29:11 Just re-iterating my quick parting comments from w
varkha 2015/11/06 20:51:50 Maybe. This however allows to refactor what we hav
+ views::InkDropState ink_drop_state = views::InkDropState::HIDDEN;
+ LOG(ERROR) << __FUNCTION__ << " event:" << event->type();
+ switch (event->type()) {
+ case ui::ET_GESTURE_TAP_DOWN:
+ ink_drop_state = views::InkDropState::ACTION_PENDING;
+ // The ui::ET_GESTURE_TAP_DOWN event needs to be marked as handled so that
+ // subsequent events for the gesture are sent to |this|.
+ event->SetHandled();
+ break;
+ case ui::ET_GESTURE_LONG_PRESS:
+ ink_drop_state = views::InkDropState::SLOW_ACTION_PENDING;
+ break;
+ case ui::ET_GESTURE_LONG_TAP:
+ ink_drop_state = views::InkDropState::SLOW_ACTION;
+ break;
+ case ui::ET_GESTURE_SCROLL_BEGIN:
+ case ui::ET_GESTURE_END:
+ ink_drop_state = views::InkDropState::HIDDEN;
+ break;
+ default:
+ return;
+ }
+
+ views::InkDropState current_ink_drop_state =
+ ink_drop_animation_controller_->GetInkDropState();
+
+ if (ink_drop_state == views::InkDropState::HIDDEN &&
+ (current_ink_drop_state == views::InkDropState::QUICK_ACTION ||
+ current_ink_drop_state == views::InkDropState::SLOW_ACTION ||
+ current_ink_drop_state == views::InkDropState::DEACTIVATED)) {
+ // These InkDropStates automatically transition to the HIDDEN state so we
+ // don't make an explicit call. Explicitly animating to HIDDEN in this case
+ // would prematurely pre-empt these animations.
+ return;
+ }
+ LOG(ERROR) << __FUNCTION__ << " state:" << (int)ink_drop_state;
+ ink_drop_animation_controller_->AnimateToState(ink_drop_state);
+}
+
+} // namespace views

Powered by Google App Engine
This is Rietveld 408576698