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

Unified Diff: ui/views/controls/touch/touch_hud_drawer.cc

Issue 2092343002: Touch HUD app for mustash (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Change window manager connection unittest to original Created 4 years, 5 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ui/views/controls/touch/touch_hud_drawer.h ('k') | ui/views/mus/native_widget_mus.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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
« no previous file with comments | « ui/views/controls/touch/touch_hud_drawer.h ('k') | ui/views/mus/native_widget_mus.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698