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

Side by Side Diff: content/browser/android/popup_touch_handle_drawable.cc

Issue 335943002: [Android] Composited selection handle rendering (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@input_native_handles_final
Patch Set: Clean up paste popup interaction Created 6 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "content/browser/android/popup_touch_handle_drawable.h"
6
7 #include "jni/PopupTouchHandleDrawable_jni.h"
8
9 namespace content {
10
11 PopupTouchHandleDrawable::PopupTouchHandleDrawable(
12 base::android::ScopedJavaLocalRef<jobject> drawable,
13 float dpi_scale)
14 : dpi_scale_(dpi_scale), drawable_(drawable) {
15 DCHECK(drawable.obj());
16 }
17
18 PopupTouchHandleDrawable::~PopupTouchHandleDrawable() {
19 }
20
21 void PopupTouchHandleDrawable::SetOrientation(
22 TouchHandleOrientation orientation) {
23 JNIEnv* env = base::android::AttachCurrentThread();
24 jobject obj = drawable_.obj();
25 switch (orientation) {
26 case TOUCH_HANDLE_LEFT:
27 Java_PopupTouchHandleDrawable_setLeftOrientation(env, obj);
28 break;
29
30 case TOUCH_HANDLE_RIGHT:
31 Java_PopupTouchHandleDrawable_setRightOrientation(env, obj);
32 break;
33
34 case TOUCH_HANDLE_CENTER:
35 Java_PopupTouchHandleDrawable_setCenterOrientation(env, obj);
36 break;
37
38 case TOUCH_HANDLE_ORIENTATION_UNDEFINED:
39 NOTREACHED() << "Invalid touch handle orientation.";
40 };
41 }
42
43 void PopupTouchHandleDrawable::SetAlpha(float alpha) {
44 JNIEnv* env = base::android::AttachCurrentThread();
45 Java_PopupTouchHandleDrawable_setOpacity(env, drawable_.obj(), alpha);
46 }
47
48 void PopupTouchHandleDrawable::SetFocus(const gfx::PointF& position) {
49 const gfx::PointF position_pix = gfx::ScalePoint(position, dpi_scale_);
50 JNIEnv* env = base::android::AttachCurrentThread();
51 Java_PopupTouchHandleDrawable_setFocus(
52 env, drawable_.obj(), position_pix.x(), position_pix.y());
53 }
54
55 void PopupTouchHandleDrawable::SetVisible(bool visible) {
56 JNIEnv* env = base::android::AttachCurrentThread();
57 Java_PopupTouchHandleDrawable_setVisible(env, drawable_.obj(), visible);
58 }
59
60 bool PopupTouchHandleDrawable::ContainsPoint(const gfx::PointF& point) const {
61 const gfx::PointF point_pix = gfx::ScalePoint(point, dpi_scale_);
62 JNIEnv* env = base::android::AttachCurrentThread();
63 return Java_PopupTouchHandleDrawable_containsPoint(
64 env, drawable_.obj(), point_pix.x(), point_pix.y());
65 }
66
67 // static
68 bool PopupTouchHandleDrawable::RegisterPopupTouchHandleDrawable(JNIEnv* env) {
69 return RegisterNativesImpl(env);
70 }
71
72 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698