Chromium Code Reviews| 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 |