| Index: ui/views/controls/touch/touch_hud_drawer.cc
|
| diff --git a/ash/touch/touch_hud_projection.cc b/ui/views/controls/touch/touch_hud_drawer.cc
|
| similarity index 69%
|
| copy from ash/touch/touch_hud_projection.cc
|
| copy to ui/views/controls/touch/touch_hud_drawer.cc
|
| index 02f604ef8d72543e6bb78242274de5c29a37161a..0779e1060e2d6606816908eac680435f0de3d565 100644
|
| --- a/ash/touch/touch_hud_projection.cc
|
| +++ b/ui/views/controls/touch/touch_hud_drawer.cc
|
| @@ -1,22 +1,22 @@
|
| -// Copyright 2013 The Chromium Authors. All rights reserved.
|
| +// Copyright 2016 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 "ash/touch/touch_hud_projection.h"
|
| +#include "ui/views/controls/touch/touch_hud_drawer.h"
|
|
|
| -#include "ash/root_window_controller.h"
|
| -#include "ash/shell.h"
|
| #include "third_party/skia/include/effects/SkGradientShader.h"
|
| #include "ui/events/event.h"
|
| #include "ui/gfx/animation/animation_delegate.h"
|
| #include "ui/gfx/animation/linear_animation.h"
|
| #include "ui/gfx/canvas.h"
|
| #include "ui/gfx/geometry/size.h"
|
| +#include "ui/views/view.h"
|
| #include "ui/views/widget/widget.h"
|
| +#include "ui/views/widget/widget_observer.h"
|
|
|
| -namespace ash {
|
| +namespace views {
|
|
|
| -const int kPointRadius = 20;
|
| +const int kPointRadius = 40;
|
| const SkColor kProjectionFillColor = SkColorSetRGB(0xF5, 0xF5, 0xDC);
|
| const SkColor kProjectionStrokeColor = SK_ColorGRAY;
|
| const int kProjectionAlpha = 0xB0;
|
| @@ -26,13 +26,14 @@ const int kFadeoutFrameRate = 60;
|
| // TouchPointView draws a single touch point. This object manages its own
|
| // lifetime and deletes itself upon fade-out completion or whenever |Remove()|
|
| // is explicitly called.
|
| -class TouchPointView : public views::View,
|
| +class TouchPointView : public View,
|
| public gfx::AnimationDelegate,
|
| - public views::WidgetObserver {
|
| + public WidgetObserver {
|
| public:
|
| - explicit TouchPointView(views::Widget* parent_widget)
|
| + explicit TouchPointView(Widget* parent_widget)
|
| : circle_center_(kPointRadius + 1, kPointRadius + 1),
|
| - gradient_center_(SkPoint::Make(kPointRadius + 1, kPointRadius + 1)) {
|
| + gradient_center_(SkPoint::Make(kPointRadius + 1,
|
| + kPointRadius + 1)) {
|
| SetPaintToLayer(true);
|
| layer()->SetFillsBoundsOpaquely(false);
|
|
|
| @@ -52,20 +53,25 @@ class TouchPointView : public views::View,
|
| parent_widget->AddObserver(this);
|
| }
|
|
|
| - void UpdateTouch(const ui::TouchEvent& touch) {
|
| + void UpdateTouch(const ui::LocatedEvent& touch) {
|
| if (touch.type() == ui::ET_TOUCH_RELEASED ||
|
| - touch.type() == ui::ET_TOUCH_CANCELLED) {
|
| + touch.type() == ui::ET_TOUCH_CANCELLED ||
|
| + touch.type() == ui::ET_POINTER_UP ||
|
| + touch.type() == ui::ET_POINTER_CANCELLED) {
|
| fadeout_.reset(new gfx::LinearAnimation(kFadeoutDurationInMs,
|
| - kFadeoutFrameRate, this));
|
| + kFadeoutFrameRate,
|
| + this));
|
| fadeout_->Start();
|
| } else {
|
| SetX(parent()->GetMirroredXInView(touch.root_location().x()) -
|
| - kPointRadius - 1);
|
| + kPointRadius - 1);
|
| SetY(touch.root_location().y() - kPointRadius - 1);
|
| }
|
| }
|
|
|
| - void Remove() { delete this; }
|
| + void Remove() {
|
| + delete this;
|
| + }
|
|
|
| private:
|
| ~TouchPointView() override {
|
| @@ -126,24 +132,31 @@ class TouchPointView : public views::View,
|
| DISALLOW_COPY_AND_ASSIGN(TouchPointView);
|
| };
|
|
|
| -TouchHudProjection::TouchHudProjection(aura::Window* initial_root)
|
| - : TouchObserverHUD(initial_root) {}
|
| +TouchHudDrawer::TouchHudDrawer() {}
|
|
|
| -TouchHudProjection::~TouchHudProjection() {}
|
| +TouchHudDrawer::~TouchHudDrawer() {}
|
|
|
| -void TouchHudProjection::Clear() {
|
| +void TouchHudDrawer::Clear() {
|
| for (std::map<int, TouchPointView*>::iterator iter = points_.begin();
|
| - iter != points_.end(); iter++)
|
| + iter != points_.end(); iter++)
|
| iter->second->Remove();
|
| points_.clear();
|
| }
|
|
|
| -void TouchHudProjection::OnTouchEvent(ui::TouchEvent* event) {
|
| - if (event->type() == ui::ET_TOUCH_PRESSED) {
|
| - TouchPointView* point = new TouchPointView(widget());
|
| +void TouchHudDrawer::HandleTouchEvent(const ui::LocatedEvent* event,
|
| + Widget* parent_widget) {
|
| + int id = 0;
|
| + if (event->IsTouchEvent()) {
|
| + id = event->AsTouchEvent()->touch_id();
|
| + } else if (event->IsPointerEvent()) {
|
| + id = event->AsPointerEvent()->pointer_id();
|
| + }
|
| + if (event->type() == ui::ET_TOUCH_PRESSED ||
|
| + event->type() == ui::ET_POINTER_DOWN) {
|
| + TouchPointView* point = new TouchPointView(parent_widget);
|
| point->UpdateTouch(*event);
|
| std::pair<std::map<int, TouchPointView*>::iterator, bool> result =
|
| - points_.insert(std::make_pair(event->touch_id(), point));
|
| + points_.insert(std::make_pair(id, point));
|
| // If a |TouchPointView| is already mapped to the touch id, remove it and
|
| // replace it with the new one.
|
| if (!result.second) {
|
| @@ -151,25 +164,16 @@ void TouchHudProjection::OnTouchEvent(ui::TouchEvent* event) {
|
| result.first->second = point;
|
| }
|
| } else {
|
| - std::map<int, TouchPointView*>::iterator iter =
|
| - points_.find(event->touch_id());
|
| + std::map<int, TouchPointView*>::iterator iter = points_.find(id);
|
| if (iter != points_.end()) {
|
| iter->second->UpdateTouch(*event);
|
| if (event->type() == ui::ET_TOUCH_RELEASED ||
|
| - event->type() == ui::ET_TOUCH_CANCELLED)
|
| + event->type() == ui::ET_TOUCH_CANCELLED ||
|
| + event->type() == ui::ET_POINTER_UP ||
|
| + event->type() == ui::ET_POINTER_CANCELLED)
|
| points_.erase(iter);
|
| }
|
| }
|
| }
|
|
|
| -void TouchHudProjection::SetHudForRootWindowController(
|
| - RootWindowController* controller) {
|
| - controller->set_touch_hud_projection(this);
|
| -}
|
| -
|
| -void TouchHudProjection::UnsetHudForRootWindowController(
|
| - RootWindowController* controller) {
|
| - controller->set_touch_hud_projection(NULL);
|
| -}
|
| -
|
| -} // namespace ash
|
| +} // namespace views
|
|
|