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 |
11 PopupTouchHandleDrawable::PopupTouchHandleDrawable( | 11 PopupTouchHandleDrawable::PopupTouchHandleDrawable( |
12 base::android::ScopedJavaLocalRef<jobject> drawable, | 12 base::android::ScopedJavaLocalRef<jobject> drawable, |
13 float dpi_scale) | 13 float dpi_scale) |
14 : dpi_scale_(dpi_scale), drawable_(drawable) { | 14 : dpi_scale_(dpi_scale), drawable_(drawable) { |
15 DCHECK(drawable.obj()); | 15 DCHECK(drawable.obj()); |
16 drawable_horizontal_padding_ = GetPaddingFromResources(); | |
16 } | 17 } |
17 | 18 |
18 PopupTouchHandleDrawable::~PopupTouchHandleDrawable() { | 19 PopupTouchHandleDrawable::~PopupTouchHandleDrawable() { |
19 // Explicitly disabling ensures that any external references to the Java | 20 // Explicitly disabling ensures that any external references to the Java |
20 // object are cleared, allowing it to be GC'ed in a timely fashion. | 21 // object are cleared, allowing it to be GC'ed in a timely fashion. |
21 SetEnabled(false); | 22 SetEnabled(false); |
22 } | 23 } |
23 | 24 |
24 void PopupTouchHandleDrawable::SetEnabled(bool enabled) { | 25 void PopupTouchHandleDrawable::SetEnabled(bool enabled) { |
25 JNIEnv* env = base::android::AttachCurrentThread(); | 26 JNIEnv* env = base::android::AttachCurrentThread(); |
26 if (enabled) | 27 if (enabled) |
27 Java_PopupTouchHandleDrawable_show(env, drawable_.obj()); | 28 Java_PopupTouchHandleDrawable_show(env, drawable_.obj()); |
28 else | 29 else |
29 Java_PopupTouchHandleDrawable_hide(env, drawable_.obj()); | 30 Java_PopupTouchHandleDrawable_hide(env, drawable_.obj()); |
30 } | 31 } |
31 | 32 |
32 void PopupTouchHandleDrawable::SetOrientation( | 33 void PopupTouchHandleDrawable::SetOrientation( |
33 ui::TouchHandleOrientation orientation) { | 34 ui::TouchHandleOrientation orientation, |
35 bool mirror_vertical, | |
36 bool mirror_horizontal) { | |
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_setOrientation( |
41 env, obj, static_cast<int>(orientation), mirror_vertical, | |
42 mirror_horizontal); | |
43 } | |
44 | |
45 void PopupTouchHandleDrawable::SetOrigin(const gfx::PointF& origin) { | |
46 JNIEnv* env = base::android::AttachCurrentThread(); | |
47 jobject obj = drawable_.obj(); | |
48 | |
49 const gfx::PointF origin_pix = gfx::ScalePoint(origin, dpi_scale_); | |
50 Java_PopupTouchHandleDrawable_setOrigin(env, obj, origin_pix.x(), | |
51 origin_pix.y()); | |
38 } | 52 } |
39 | 53 |
40 void PopupTouchHandleDrawable::SetAlpha(float alpha) { | 54 void PopupTouchHandleDrawable::SetAlpha(float alpha) { |
41 JNIEnv* env = base::android::AttachCurrentThread(); | 55 JNIEnv* env = base::android::AttachCurrentThread(); |
42 bool visible = alpha > 0; | 56 bool visible = alpha > 0; |
43 Java_PopupTouchHandleDrawable_setVisible(env, drawable_.obj(), visible); | 57 Java_PopupTouchHandleDrawable_setVisible(env, drawable_.obj(), visible); |
44 } | 58 } |
45 | 59 |
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 { | 60 gfx::RectF PopupTouchHandleDrawable::GetVisibleBounds() const { |
54 JNIEnv* env = base::android::AttachCurrentThread(); | 61 JNIEnv* env = base::android::AttachCurrentThread(); |
55 gfx::RectF unscaled_rect( | 62 gfx::RectF unscaled_rect( |
56 Java_PopupTouchHandleDrawable_getPositionX(env, drawable_.obj()), | 63 Java_PopupTouchHandleDrawable_getPositionX(env, drawable_.obj()), |
57 Java_PopupTouchHandleDrawable_getPositionY(env, drawable_.obj()), | 64 Java_PopupTouchHandleDrawable_getPositionY(env, drawable_.obj()), |
58 Java_PopupTouchHandleDrawable_getVisibleWidth(env, drawable_.obj()), | 65 Java_PopupTouchHandleDrawable_getVisibleWidth(env, drawable_.obj()), |
59 Java_PopupTouchHandleDrawable_getVisibleHeight(env, drawable_.obj())); | 66 Java_PopupTouchHandleDrawable_getVisibleHeight(env, drawable_.obj())); |
60 return gfx::ScaleRect(unscaled_rect, 1.f / dpi_scale_); | 67 return gfx::ScaleRect(unscaled_rect, 1.f / dpi_scale_); |
61 } | 68 } |
62 | 69 |
70 const float PopupTouchHandleDrawable::GetPaddingFromResources() { | |
jdduke (slow)
2015/08/17 17:20:50
Nit: This is only use once, let's just inline it i
AviD
2015/08/18 13:56:14
Done.
| |
71 JNIEnv* env = base::android::AttachCurrentThread(); | |
72 const float horizontal_padding = | |
73 Java_PopupTouchHandleDrawable_getHandleHorizontalPadding(env, | |
74 drawable_.obj()); | |
75 return horizontal_padding; | |
76 } | |
77 | |
78 const float PopupTouchHandleDrawable::GetDrawableHorizontalPadding() const { | |
79 return drawable_horizontal_padding_; | |
80 } | |
81 | |
63 // static | 82 // static |
64 bool PopupTouchHandleDrawable::RegisterPopupTouchHandleDrawable(JNIEnv* env) { | 83 bool PopupTouchHandleDrawable::RegisterPopupTouchHandleDrawable(JNIEnv* env) { |
65 return RegisterNativesImpl(env); | 84 return RegisterNativesImpl(env); |
66 } | 85 } |
67 | 86 |
68 } // namespace content | 87 } // namespace content |
OLD | NEW |