OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 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 "content/browser/android/popup_touch_handle_drawable.h" | 5 #include "content/browser/android/popup_touch_handle_drawable.h" |
6 | 6 |
7 #include "jni/PopupTouchHandleDrawable_jni.h" | 7 #include "jni/PopupTouchHandleDrawable_jni.h" |
8 | 8 |
9 namespace content { | 9 namespace content { |
10 | 10 |
(...skipping 11 matching lines...) Expand all Loading... |
22 } | 22 } |
23 | 23 |
24 void PopupTouchHandleDrawable::SetEnabled(bool enabled) { | 24 void PopupTouchHandleDrawable::SetEnabled(bool enabled) { |
25 JNIEnv* env = base::android::AttachCurrentThread(); | 25 JNIEnv* env = base::android::AttachCurrentThread(); |
26 if (enabled) | 26 if (enabled) |
27 Java_PopupTouchHandleDrawable_show(env, drawable_.obj()); | 27 Java_PopupTouchHandleDrawable_show(env, drawable_.obj()); |
28 else | 28 else |
29 Java_PopupTouchHandleDrawable_hide(env, drawable_.obj()); | 29 Java_PopupTouchHandleDrawable_hide(env, drawable_.obj()); |
30 } | 30 } |
31 | 31 |
32 void PopupTouchHandleDrawable::SetOrientation( | 32 void PopupTouchHandleDrawable::SetLayout(const gfx::PointF& position, |
33 ui::TouchHandleOrientation orientation) { | 33 ui::TouchHandleOrientation orientation, |
| 34 bool mirror_vertical, |
| 35 bool mirror_horizontal) { |
| 36 const gfx::PointF position_pix = gfx::ScalePoint(position, dpi_scale_); |
34 JNIEnv* env = base::android::AttachCurrentThread(); | 37 JNIEnv* env = base::android::AttachCurrentThread(); |
35 jobject obj = drawable_.obj(); | 38 jobject obj = drawable_.obj(); |
36 Java_PopupTouchHandleDrawable_setOrientation(env, obj, | 39 |
37 static_cast<int>(orientation)); | 40 Java_PopupTouchHandleDrawable_setFocus(env, obj, position_pix.x(), |
| 41 position_pix.y()); |
| 42 |
| 43 Java_PopupTouchHandleDrawable_setOrientation( |
| 44 env, obj, static_cast<int>(orientation), mirror_vertical, |
| 45 mirror_horizontal); |
38 } | 46 } |
39 | 47 |
40 void PopupTouchHandleDrawable::SetAlpha(float alpha) { | 48 void PopupTouchHandleDrawable::SetAlpha(float alpha) { |
41 JNIEnv* env = base::android::AttachCurrentThread(); | 49 JNIEnv* env = base::android::AttachCurrentThread(); |
42 bool visible = alpha > 0; | 50 bool visible = alpha > 0; |
43 Java_PopupTouchHandleDrawable_setVisible(env, drawable_.obj(), visible); | 51 Java_PopupTouchHandleDrawable_setVisible(env, drawable_.obj(), visible); |
44 } | 52 } |
45 | 53 |
46 void PopupTouchHandleDrawable::SetFocus(const gfx::PointF& position) { | |
47 const gfx::PointF position_pix = gfx::ScalePoint(position, dpi_scale_); | |
48 JNIEnv* env = base::android::AttachCurrentThread(); | |
49 Java_PopupTouchHandleDrawable_setFocus( | |
50 env, drawable_.obj(), position_pix.x(), position_pix.y()); | |
51 } | |
52 | |
53 gfx::RectF PopupTouchHandleDrawable::GetVisibleBounds() const { | 54 gfx::RectF PopupTouchHandleDrawable::GetVisibleBounds() const { |
54 JNIEnv* env = base::android::AttachCurrentThread(); | 55 JNIEnv* env = base::android::AttachCurrentThread(); |
55 gfx::RectF unscaled_rect( | 56 gfx::RectF unscaled_rect( |
56 Java_PopupTouchHandleDrawable_getPositionX(env, drawable_.obj()), | 57 Java_PopupTouchHandleDrawable_getPositionX(env, drawable_.obj()), |
57 Java_PopupTouchHandleDrawable_getPositionY(env, drawable_.obj()), | 58 Java_PopupTouchHandleDrawable_getPositionY(env, drawable_.obj()), |
58 Java_PopupTouchHandleDrawable_getVisibleWidth(env, drawable_.obj()), | 59 Java_PopupTouchHandleDrawable_getVisibleWidth(env, drawable_.obj()), |
59 Java_PopupTouchHandleDrawable_getVisibleHeight(env, drawable_.obj())); | 60 Java_PopupTouchHandleDrawable_getVisibleHeight(env, drawable_.obj())); |
60 return gfx::ScaleRect(unscaled_rect, 1.f / dpi_scale_); | 61 return gfx::ScaleRect(unscaled_rect, 1.f / dpi_scale_); |
61 } | 62 } |
62 | 63 |
63 // static | 64 // static |
64 bool PopupTouchHandleDrawable::RegisterPopupTouchHandleDrawable(JNIEnv* env) { | 65 bool PopupTouchHandleDrawable::RegisterPopupTouchHandleDrawable(JNIEnv* env) { |
65 return RegisterNativesImpl(env); | 66 return RegisterNativesImpl(env); |
66 } | 67 } |
67 | 68 |
68 } // namespace content | 69 } // namespace content |
OLD | NEW |