Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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/content_view_core_impl.h" | 5 #include "content/browser/android/content_view_core_impl.h" |
| 6 | 6 |
| 7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
| 8 #include "base/android/jni_array.h" | 8 #include "base/android/jni_array.h" |
| 9 #include "base/android/jni_string.h" | 9 #include "base/android/jni_string.h" |
| 10 #include "base/android/scoped_java_ref.h" | 10 #include "base/android/scoped_java_ref.h" |
| 11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
| 12 #include "base/json/json_writer.h" | 12 #include "base/json/json_writer.h" |
| 13 #include "base/logging.h" | 13 #include "base/logging.h" |
| 14 #include "base/metrics/histogram.h" | 14 #include "base/metrics/histogram.h" |
| 15 #include "base/strings/utf_string_conversions.h" | 15 #include "base/strings/utf_string_conversions.h" |
| 16 #include "base/values.h" | 16 #include "base/values.h" |
| 17 #include "cc/layers/layer.h" | 17 #include "cc/layers/layer.h" |
| 18 #include "cc/layers/solid_color_layer.h" | 18 #include "cc/layers/solid_color_layer.h" |
| 19 #include "cc/output/begin_frame_args.h" | 19 #include "cc/output/begin_frame_args.h" |
| 20 #include "content/browser/android/gesture_event_type.h" | 20 #include "content/browser/android/gesture_event_type.h" |
| 21 #include "content/browser/android/interstitial_page_delegate_android.h" | 21 #include "content/browser/android/interstitial_page_delegate_android.h" |
| 22 #include "content/browser/android/java/java_bound_object.h" | 22 #include "content/browser/android/java/java_bound_object.h" |
| 23 #include "content/browser/android/java/java_bridge_dispatcher_host_manager.h" | 23 #include "content/browser/android/java/java_bridge_dispatcher_host_manager.h" |
| 24 #include "content/browser/android/load_url_params.h" | 24 #include "content/browser/android/load_url_params.h" |
| 25 #include "content/browser/android/popup_touch_handle_drawable.h" | |
| 25 #include "content/browser/frame_host/interstitial_page_impl.h" | 26 #include "content/browser/frame_host/interstitial_page_impl.h" |
| 26 #include "content/browser/frame_host/navigation_controller_impl.h" | 27 #include "content/browser/frame_host/navigation_controller_impl.h" |
| 27 #include "content/browser/frame_host/navigation_entry_impl.h" | 28 #include "content/browser/frame_host/navigation_entry_impl.h" |
| 28 #include "content/browser/geolocation/geolocation_dispatcher_host.h" | 29 #include "content/browser/geolocation/geolocation_dispatcher_host.h" |
| 29 #include "content/browser/media/media_web_contents_observer.h" | 30 #include "content/browser/media/media_web_contents_observer.h" |
| 30 #include "content/browser/renderer_host/compositor_impl_android.h" | 31 #include "content/browser/renderer_host/compositor_impl_android.h" |
| 31 #include "content/browser/renderer_host/input/motion_event_android.h" | 32 #include "content/browser/renderer_host/input/motion_event_android.h" |
| 32 #include "content/browser/renderer_host/input/web_input_event_builders_android.h " | 33 #include "content/browser/renderer_host/input/web_input_event_builders_android.h " |
| 33 #include "content/browser/renderer_host/input/web_input_event_util.h" | 34 #include "content/browser/renderer_host/input/web_input_event_util.h" |
| 34 #include "content/browser/renderer_host/render_view_host_impl.h" | 35 #include "content/browser/renderer_host/render_view_host_impl.h" |
| (...skipping 509 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 544 Java_ContentViewCore_onPinchEndEventAck(env, j_obj.obj()); | 545 Java_ContentViewCore_onPinchEndEventAck(env, j_obj.obj()); |
| 545 break; | 546 break; |
| 546 case WebInputEvent::GestureTap: | 547 case WebInputEvent::GestureTap: |
| 547 Java_ContentViewCore_onSingleTapEventAck( | 548 Java_ContentViewCore_onSingleTapEventAck( |
| 548 env, | 549 env, |
| 549 j_obj.obj(), | 550 j_obj.obj(), |
| 550 ack_result == INPUT_EVENT_ACK_STATE_CONSUMED, | 551 ack_result == INPUT_EVENT_ACK_STATE_CONSUMED, |
| 551 event.x * dpi_scale(), | 552 event.x * dpi_scale(), |
| 552 event.y * dpi_scale()); | 553 event.y * dpi_scale()); |
| 553 break; | 554 break; |
| 554 case WebInputEvent::GestureDoubleTap: | |
| 555 Java_ContentViewCore_onDoubleTapEventAck(env, j_obj.obj()); | |
| 556 break; | |
| 557 default: | 555 default: |
| 558 break; | 556 break; |
| 559 } | 557 } |
| 560 } | 558 } |
| 561 | 559 |
| 562 bool ContentViewCoreImpl::FilterInputEvent(const blink::WebInputEvent& event) { | 560 bool ContentViewCoreImpl::FilterInputEvent(const blink::WebInputEvent& event) { |
| 563 if (event.type != WebInputEvent::GestureTap && | 561 if (event.type != WebInputEvent::GestureTap && |
| 564 event.type != WebInputEvent::GestureDoubleTap && | 562 event.type != WebInputEvent::GestureDoubleTap && |
| 565 event.type != WebInputEvent::GestureLongTap && | 563 event.type != WebInputEvent::GestureLongTap && |
| 566 event.type != WebInputEvent::GestureLongPress) | 564 event.type != WebInputEvent::GestureLongPress) |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 593 | 591 |
| 594 void ContentViewCoreImpl::OnSelectionChanged(const std::string& text) { | 592 void ContentViewCoreImpl::OnSelectionChanged(const std::string& text) { |
| 595 JNIEnv* env = AttachCurrentThread(); | 593 JNIEnv* env = AttachCurrentThread(); |
| 596 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); | 594 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); |
| 597 if (obj.is_null()) | 595 if (obj.is_null()) |
| 598 return; | 596 return; |
| 599 ScopedJavaLocalRef<jstring> jtext = ConvertUTF8ToJavaString(env, text); | 597 ScopedJavaLocalRef<jstring> jtext = ConvertUTF8ToJavaString(env, text); |
| 600 Java_ContentViewCore_onSelectionChanged(env, obj.obj(), jtext.obj()); | 598 Java_ContentViewCore_onSelectionChanged(env, obj.obj(), jtext.obj()); |
| 601 } | 599 } |
| 602 | 600 |
| 603 void ContentViewCoreImpl::OnSelectionBoundsChanged(const gfx::PointF& anchor, | 601 void ContentViewCoreImpl::OnSelectionEvent(SelectionEventType event, |
| 604 const gfx::PointF& focus, | 602 const gfx::PointF& position) { |
| 605 int anchor_dir, | 603 JNIEnv* env = AttachCurrentThread(); |
| 606 int focus_dir, | 604 ScopedJavaLocalRef<jobject> j_obj = java_ref_.get(env); |
| 607 bool is_anchor_visible, | 605 if (j_obj.is_null()) |
| 608 bool is_focus_visible) { | 606 return; |
| 607 Java_ContentViewCore_onSelectionEvent( | |
| 608 env, j_obj.obj(), event, position.x(), position.y()); | |
| 609 } | |
| 610 | |
| 611 scoped_ptr<TouchHandleDrawable> | |
| 612 ContentViewCoreImpl::CreatePopupTouchHandleDrawable() { | |
| 609 JNIEnv* env = AttachCurrentThread(); | 613 JNIEnv* env = AttachCurrentThread(); |
| 610 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); | 614 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); |
| 611 if (obj.is_null()) | 615 if (obj.is_null()) { |
| 612 return; | 616 NOTREACHED(); |
| 613 Java_ContentViewCore_onSelectionBoundsChanged(env, | 617 return scoped_ptr<TouchHandleDrawable>(); |
| 614 obj.obj(), | 618 } |
| 615 anchor.x(), | 619 return scoped_ptr<TouchHandleDrawable>(new PopupTouchHandleDrawable( |
| 616 anchor.y(), | 620 Java_ContentViewCore_createPopupTouchHandleDrawable(env, obj.obj()), |
| 617 focus.x(), | 621 dpi_scale_)); |
| 618 focus.y(), | |
| 619 anchor_dir, | |
| 620 focus_dir, | |
| 621 is_anchor_visible, | |
| 622 is_focus_visible); | |
| 623 } | 622 } |
| 624 | 623 |
| 625 void ContentViewCoreImpl::ShowPastePopup(int x_dip, int y_dip) { | 624 void ContentViewCoreImpl::ShowPastePopup(int x_dip, int y_dip) { |
| 626 JNIEnv* env = AttachCurrentThread(); | 625 JNIEnv* env = AttachCurrentThread(); |
| 627 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); | 626 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); |
| 628 if (obj.is_null()) | 627 if (obj.is_null()) |
| 629 return; | 628 return; |
| 630 Java_ContentViewCore_showPastePopup(env, obj.obj(), | 629 Java_ContentViewCore_showPastePopup(env, obj.obj(), |
| 631 static_cast<jint>(x_dip), | 630 static_cast<jint>(x_dip), |
| 632 static_cast<jint>(y_dip)); | 631 static_cast<jint>(y_dip)); |
| (...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 778 float ContentViewCoreImpl::GetOverdrawBottomHeightDip() const { | 777 float ContentViewCoreImpl::GetOverdrawBottomHeightDip() const { |
| 779 JNIEnv* env = AttachCurrentThread(); | 778 JNIEnv* env = AttachCurrentThread(); |
| 780 ScopedJavaLocalRef<jobject> j_obj = java_ref_.get(env); | 779 ScopedJavaLocalRef<jobject> j_obj = java_ref_.get(env); |
| 781 if (j_obj.is_null()) | 780 if (j_obj.is_null()) |
| 782 return 0.f; | 781 return 0.f; |
| 783 return Java_ContentViewCore_getOverdrawBottomHeightPix(env, j_obj.obj()) | 782 return Java_ContentViewCore_getOverdrawBottomHeightPix(env, j_obj.obj()) |
| 784 / dpi_scale(); | 783 / dpi_scale(); |
| 785 } | 784 } |
| 786 | 785 |
| 787 void ContentViewCoreImpl::AttachLayer(scoped_refptr<cc::Layer> layer) { | 786 void ContentViewCoreImpl::AttachLayer(scoped_refptr<cc::Layer> layer) { |
| 788 root_layer_->AddChild(layer); | 787 root_layer_->InsertChild(layer, 0); |
| 789 root_layer_->SetIsDrawable(false); | 788 root_layer_->SetIsDrawable(false); |
| 790 } | 789 } |
| 791 | 790 |
| 792 void ContentViewCoreImpl::RemoveLayer(scoped_refptr<cc::Layer> layer) { | 791 void ContentViewCoreImpl::RemoveLayer(scoped_refptr<cc::Layer> layer) { |
| 793 layer->RemoveFromParent(); | 792 layer->RemoveFromParent(); |
| 794 | 793 |
| 795 if (!root_layer_->children().size()) | 794 if (!root_layer_->children().size()) |
| 796 root_layer_->SetIsDrawable(true); | 795 root_layer_->SetIsDrawable(true); |
| 797 } | 796 } |
| 798 | 797 |
| 798 void ContentViewCoreImpl::SelectBetweenCoordinates(const gfx::PointF& start, | |
| 799 const gfx::PointF& end) { | |
| 800 if (!web_contents_) | |
| 801 return; | |
| 802 | |
| 803 gfx::Point anchor = gfx::Point(start.x(), start.y()); | |
| 804 gfx::Point focus = gfx::Point(end.x(), end.y()); | |
| 805 if (anchor.x() == focus.x() && anchor.y() == focus.y()) | |
|
cjhopman
2014/07/09 22:29:12
nit: if (anchor == focus) {
jdduke (slow)
2014/07/10 02:08:39
Done.
| |
| 806 return; | |
| 807 | |
| 808 web_contents_->SelectRange(anchor, focus); | |
| 809 } | |
| 810 | |
| 799 void ContentViewCoreImpl::LoadUrl( | 811 void ContentViewCoreImpl::LoadUrl( |
| 800 NavigationController::LoadURLParams& params) { | 812 NavigationController::LoadURLParams& params) { |
| 801 GetWebContents()->GetController().LoadURLWithParams(params); | 813 GetWebContents()->GetController().LoadURLWithParams(params); |
| 802 } | 814 } |
| 803 | 815 |
| 804 ui::ViewAndroid* ContentViewCoreImpl::GetViewAndroid() const { | 816 ui::ViewAndroid* ContentViewCoreImpl::GetViewAndroid() const { |
| 805 // view_android_ should never be null for Chrome. | 817 // view_android_ should never be null for Chrome. |
| 806 DCHECK(view_android_); | 818 DCHECK(view_android_); |
| 807 return view_android_; | 819 return view_android_; |
| 808 } | 820 } |
| (...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 977 touch_major_1, | 989 touch_major_1, |
| 978 raw_pos_x, | 990 raw_pos_x, |
| 979 raw_pos_y, | 991 raw_pos_y, |
| 980 android_tool_type_0, | 992 android_tool_type_0, |
| 981 android_tool_type_1, | 993 android_tool_type_1, |
| 982 android_button_state); | 994 android_button_state); |
| 983 | 995 |
| 984 return rwhv->OnTouchEvent(event); | 996 return rwhv->OnTouchEvent(event); |
| 985 } | 997 } |
| 986 | 998 |
| 999 jboolean ContentViewCoreImpl::OnTouchHandleEvent(JNIEnv* env, | |
| 1000 jobject obj, | |
| 1001 jobject motion_event) { | |
| 1002 RenderWidgetHostViewAndroid* rwhv = GetRenderWidgetHostViewAndroid(); | |
| 1003 // Avoid synthesizing a touch event if it cannot be forwarded. | |
| 1004 if (!rwhv) | |
| 1005 return false; | |
| 1006 | |
| 1007 const bool recycle = false; | |
| 1008 MotionEventAndroid event(1.f / dpi_scale(), env, motion_event, recycle); | |
| 1009 | |
| 1010 return rwhv->OnTouchHandleEvent(event); | |
| 1011 } | |
| 1012 | |
| 987 float ContentViewCoreImpl::GetDpiScale() const { | 1013 float ContentViewCoreImpl::GetDpiScale() const { |
| 988 return dpi_scale_; | 1014 return dpi_scale_; |
| 989 } | 1015 } |
| 990 | 1016 |
| 991 jboolean ContentViewCoreImpl::SendMouseMoveEvent(JNIEnv* env, | 1017 jboolean ContentViewCoreImpl::SendMouseMoveEvent(JNIEnv* env, |
| 992 jobject obj, | 1018 jobject obj, |
| 993 jlong time_ms, | 1019 jlong time_ms, |
| 994 jfloat x, | 1020 jfloat x, |
| 995 jfloat y) { | 1021 jfloat y) { |
| 996 RenderWidgetHostViewAndroid* rwhv = GetRenderWidgetHostViewAndroid(); | 1022 RenderWidgetHostViewAndroid* rwhv = GetRenderWidgetHostViewAndroid(); |
| (...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1138 WebGestureEvent event = MakeGestureEvent( | 1164 WebGestureEvent event = MakeGestureEvent( |
| 1139 WebInputEvent::GesturePinchUpdate, time_ms, anchor_x, anchor_y); | 1165 WebInputEvent::GesturePinchUpdate, time_ms, anchor_x, anchor_y); |
| 1140 event.data.pinchUpdate.scale = delta; | 1166 event.data.pinchUpdate.scale = delta; |
| 1141 | 1167 |
| 1142 SendGestureEvent(event); | 1168 SendGestureEvent(event); |
| 1143 } | 1169 } |
| 1144 | 1170 |
| 1145 void ContentViewCoreImpl::SelectBetweenCoordinates(JNIEnv* env, jobject obj, | 1171 void ContentViewCoreImpl::SelectBetweenCoordinates(JNIEnv* env, jobject obj, |
| 1146 jfloat x1, jfloat y1, | 1172 jfloat x1, jfloat y1, |
| 1147 jfloat x2, jfloat y2) { | 1173 jfloat x2, jfloat y2) { |
| 1148 if (!web_contents_) | 1174 SelectBetweenCoordinates(gfx::PointF(x1 / dpi_scale(), y1 / dpi_scale()), |
| 1149 return; | 1175 gfx::PointF(x2 / dpi_scale(), y2 / dpi_scale())); |
| 1150 | |
| 1151 web_contents_->SelectRange( | |
| 1152 gfx::Point(x1 / dpi_scale(), y1 / dpi_scale()), | |
| 1153 gfx::Point(x2 / dpi_scale(), y2 / dpi_scale())); | |
| 1154 } | 1176 } |
| 1155 | 1177 |
| 1156 void ContentViewCoreImpl::MoveCaret(JNIEnv* env, jobject obj, | 1178 void ContentViewCoreImpl::MoveCaret(JNIEnv* env, jobject obj, |
| 1157 jfloat x, jfloat y) { | 1179 jfloat x, jfloat y) { |
| 1158 if (GetRenderWidgetHostViewAndroid()) { | 1180 if (GetRenderWidgetHostViewAndroid()) { |
| 1159 GetRenderWidgetHostViewAndroid()->MoveCaret( | 1181 GetRenderWidgetHostViewAndroid()->MoveCaret( |
| 1160 gfx::Point(x / dpi_scale(), y / dpi_scale())); | 1182 gfx::Point(x / dpi_scale_, y / dpi_scale_)); |
| 1161 } | 1183 } |
| 1162 } | 1184 } |
| 1163 | 1185 |
| 1186 void ContentViewCoreImpl::HideTextHandles(JNIEnv* env, jobject obj) { | |
| 1187 if (GetRenderWidgetHostViewAndroid()) | |
| 1188 GetRenderWidgetHostViewAndroid()->HideTextHandles(); | |
| 1189 } | |
| 1190 | |
| 1164 void ContentViewCoreImpl::ResetGestureDetection(JNIEnv* env, jobject obj) { | 1191 void ContentViewCoreImpl::ResetGestureDetection(JNIEnv* env, jobject obj) { |
| 1165 RenderWidgetHostViewAndroid* rwhv = GetRenderWidgetHostViewAndroid(); | 1192 RenderWidgetHostViewAndroid* rwhv = GetRenderWidgetHostViewAndroid(); |
| 1166 if (rwhv) | 1193 if (rwhv) |
| 1167 rwhv->ResetGestureDetection(); | 1194 rwhv->ResetGestureDetection(); |
| 1168 } | 1195 } |
| 1169 | 1196 |
| 1170 void ContentViewCoreImpl::SetDoubleTapSupportEnabled(JNIEnv* env, | 1197 void ContentViewCoreImpl::SetDoubleTapSupportEnabled(JNIEnv* env, |
| 1171 jobject obj, | 1198 jobject obj, |
| 1172 jboolean enabled) { | 1199 jboolean enabled) { |
| 1173 RenderWidgetHostViewAndroid* rwhv = GetRenderWidgetHostViewAndroid(); | 1200 RenderWidgetHostViewAndroid* rwhv = GetRenderWidgetHostViewAndroid(); |
| (...skipping 354 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1528 static_cast<NavigationControllerImpl&>(web_contents_->GetController()); | 1555 static_cast<NavigationControllerImpl&>(web_contents_->GetController()); |
| 1529 controller.ReloadOriginalRequestURL(false); | 1556 controller.ReloadOriginalRequestURL(false); |
| 1530 } | 1557 } |
| 1531 } | 1558 } |
| 1532 | 1559 |
| 1533 void ContentViewCoreImpl::SetAccessibilityEnabled(JNIEnv* env, jobject obj, | 1560 void ContentViewCoreImpl::SetAccessibilityEnabled(JNIEnv* env, jobject obj, |
| 1534 bool enabled) { | 1561 bool enabled) { |
| 1535 SetAccessibilityEnabledInternal(enabled); | 1562 SetAccessibilityEnabledInternal(enabled); |
| 1536 } | 1563 } |
| 1537 | 1564 |
| 1538 void ContentViewCoreImpl::ShowSelectionHandlesAutomatically() const { | |
| 1539 JNIEnv* env = AttachCurrentThread(); | |
| 1540 ScopedJavaLocalRef<jobject> obj(java_ref_.get(env)); | |
| 1541 if (obj.is_null()) | |
| 1542 return; | |
| 1543 Java_ContentViewCore_showSelectionHandlesAutomatically(env, obj.obj()); | |
| 1544 } | |
| 1545 | |
| 1546 bool ContentViewCoreImpl::IsFullscreenRequiredForOrientationLock() const { | 1565 bool ContentViewCoreImpl::IsFullscreenRequiredForOrientationLock() const { |
| 1547 JNIEnv* env = AttachCurrentThread(); | 1566 JNIEnv* env = AttachCurrentThread(); |
| 1548 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); | 1567 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); |
| 1549 if (obj.is_null()) | 1568 if (obj.is_null()) |
| 1550 return true; | 1569 return true; |
| 1551 return Java_ContentViewCore_isFullscreenRequiredForOrientationLock(env, | 1570 return Java_ContentViewCore_isFullscreenRequiredForOrientationLock(env, |
| 1552 obj.obj()); | 1571 obj.obj()); |
| 1553 } | 1572 } |
| 1554 | 1573 |
| 1555 void ContentViewCoreImpl::SetAccessibilityEnabledInternal(bool enabled) { | 1574 void ContentViewCoreImpl::SetAccessibilityEnabledInternal(bool enabled) { |
| (...skipping 147 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1703 reinterpret_cast<ui::WindowAndroid*>(window_android), | 1722 reinterpret_cast<ui::WindowAndroid*>(window_android), |
| 1704 retained_objects_set); | 1723 retained_objects_set); |
| 1705 return reinterpret_cast<intptr_t>(view); | 1724 return reinterpret_cast<intptr_t>(view); |
| 1706 } | 1725 } |
| 1707 | 1726 |
| 1708 bool RegisterContentViewCore(JNIEnv* env) { | 1727 bool RegisterContentViewCore(JNIEnv* env) { |
| 1709 return RegisterNativesImpl(env); | 1728 return RegisterNativesImpl(env); |
| 1710 } | 1729 } |
| 1711 | 1730 |
| 1712 } // namespace content | 1731 } // namespace content |
| OLD | NEW |