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" |
| (...skipping 563 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 574 } | 574 } |
| 575 | 575 |
| 576 bool ContentViewCoreImpl::HasFocus() { | 576 bool ContentViewCoreImpl::HasFocus() { |
| 577 JNIEnv* env = AttachCurrentThread(); | 577 JNIEnv* env = AttachCurrentThread(); |
| 578 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); | 578 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); |
| 579 if (obj.is_null()) | 579 if (obj.is_null()) |
| 580 return false; | 580 return false; |
| 581 return Java_ContentViewCore_hasFocus(env, obj.obj()); | 581 return Java_ContentViewCore_hasFocus(env, obj.obj()); |
| 582 } | 582 } |
| 583 | 583 |
| 584 bool ContentViewCoreImpl::IsFocusable() { | |
| 585 JNIEnv* env = AttachCurrentThread(); | |
| 586 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); | |
| 587 if (obj.is_null()) | |
| 588 return false; | |
| 589 return Java_ContentViewCore_isFocusable(env, obj.obj()); | |
| 590 } | |
| 591 | |
| 584 void ContentViewCoreImpl::OnSelectionChanged(const std::string& text) { | 592 void ContentViewCoreImpl::OnSelectionChanged(const std::string& text) { |
| 585 JNIEnv* env = AttachCurrentThread(); | 593 JNIEnv* env = AttachCurrentThread(); |
| 586 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); | 594 ScopedJavaLocalRef<jobject> obj = java_ref_.get(env); |
| 587 if (obj.is_null()) | 595 if (obj.is_null()) |
| 588 return; | 596 return; |
| 589 ScopedJavaLocalRef<jstring> jtext = ConvertUTF8ToJavaString(env, text); | 597 ScopedJavaLocalRef<jstring> jtext = ConvertUTF8ToJavaString(env, text); |
| 590 Java_ContentViewCore_onSelectionChanged(env, obj.obj(), jtext.obj()); | 598 Java_ContentViewCore_onSelectionChanged(env, obj.obj(), jtext.obj()); |
| 591 } | 599 } |
| 592 | 600 |
| 593 void ContentViewCoreImpl::OnSelectionEvent(SelectionEventType event, | 601 void ContentViewCoreImpl::OnSelectionEvent(SelectionEventType event, |
| (...skipping 238 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 832 } | 840 } |
| 833 | 841 |
| 834 void ContentViewCoreImpl::SetFocus(JNIEnv* env, jobject obj, jboolean focused) { | 842 void ContentViewCoreImpl::SetFocus(JNIEnv* env, jobject obj, jboolean focused) { |
| 835 SetFocusInternal(focused); | 843 SetFocusInternal(focused); |
| 836 } | 844 } |
| 837 | 845 |
| 838 void ContentViewCoreImpl::SetFocusInternal(bool focused) { | 846 void ContentViewCoreImpl::SetFocusInternal(bool focused) { |
| 839 if (!GetRenderWidgetHostViewAndroid()) | 847 if (!GetRenderWidgetHostViewAndroid()) |
| 840 return; | 848 return; |
| 841 | 849 |
| 850 if (!IsFocusable()) { | |
| 851 LOG(WARN) << "Unfocusable container view, treating as always focused."; | |
|
jdduke (slow)
2014/11/05 21:20:31
Hmm, we know that this condition exists, will the
| |
| 852 focused = true; | |
| 853 } | |
| 854 | |
| 842 if (focused) | 855 if (focused) |
| 843 GetRenderWidgetHostViewAndroid()->Focus(); | 856 GetRenderWidgetHostViewAndroid()->Focus(); |
| 844 else | 857 else |
| 845 GetRenderWidgetHostViewAndroid()->Blur(); | 858 GetRenderWidgetHostViewAndroid()->Blur(); |
| 846 } | 859 } |
| 847 | 860 |
| 848 void ContentViewCoreImpl::SendOrientationChangeEvent(JNIEnv* env, | 861 void ContentViewCoreImpl::SendOrientationChangeEvent(JNIEnv* env, |
| 849 jobject obj, | 862 jobject obj, |
| 850 jint orientation) { | 863 jint orientation) { |
| 851 if (device_orientation_ != orientation) { | 864 if (device_orientation_ != orientation) { |
| (...skipping 473 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1325 reinterpret_cast<ui::WindowAndroid*>(window_android), | 1338 reinterpret_cast<ui::WindowAndroid*>(window_android), |
| 1326 retained_objects_set); | 1339 retained_objects_set); |
| 1327 return reinterpret_cast<intptr_t>(view); | 1340 return reinterpret_cast<intptr_t>(view); |
| 1328 } | 1341 } |
| 1329 | 1342 |
| 1330 bool RegisterContentViewCore(JNIEnv* env) { | 1343 bool RegisterContentViewCore(JNIEnv* env) { |
| 1331 return RegisterNativesImpl(env); | 1344 return RegisterNativesImpl(env); |
| 1332 } | 1345 } |
| 1333 | 1346 |
| 1334 } // namespace content | 1347 } // namespace content |
| OLD | NEW |