View: implement requestFocus() and isFocused()

This commit is contained in:
Julian Winkler
2024-11-30 17:44:53 +01:00
committed by Mis012
parent d0952101a6
commit fe7790c4ff
3 changed files with 38 additions and 2 deletions

View File

@@ -343,6 +343,14 @@ JNIEXPORT void JNICALL Java_android_view_View_native_1drawBackground
JNIEXPORT void JNICALL Java_android_view_View_native_1drawContent
(JNIEnv *, jobject, jlong, jlong);
/*
* Class: android_view_View
* Method: nativeRequestFocus
* Signature: (JI)V
*/
JNIEXPORT void JNICALL Java_android_view_View_nativeRequestFocus
(JNIEnv *, jobject, jlong, jint);
/*
* Class: android_view_View
* Method: nativeSetFullscreen
@@ -391,6 +399,14 @@ JNIEXPORT void JNICALL Java_android_view_View_native_1setPadding
JNIEXPORT void JNICALL Java_android_view_View_nativeSetOnLongClickListener
(JNIEnv *, jobject, jlong);
/*
* Class: android_view_View
* Method: nativeIsFocused
* Signature: (J)Z
*/
JNIEXPORT jboolean JNICALL Java_android_view_View_nativeIsFocused
(JNIEnv *, jclass, jlong);
/*
* Class: android_view_View
* Method: native_getMatrix

View File

@@ -665,4 +665,19 @@ JNIEXPORT void JNICALL Java_android_view_View_native_1removeClasses(JNIEnv *env,
(*env)->ReleaseStringUTFChars(env, class_name_jstr, class_name);
}
}
}
JNIEXPORT void JNICALL Java_android_view_View_nativeRequestFocus(JNIEnv *env, jobject this, jlong widget_ptr, jint direction) {
GtkWidget *widget = GTK_WIDGET(_PTR(widget_ptr));
GtkWidget *wrapper = gtk_widget_get_parent(widget);
if (gtk_widget_get_focusable(widget))
gtk_widget_grab_focus(widget);
else
gtk_widget_grab_focus(wrapper);
}
JNIEXPORT jboolean JNICALL Java_android_view_View_nativeIsFocused(JNIEnv *env, jobject this, jlong widget_ptr) {
GtkWidget *widget = GTK_WIDGET(_PTR(widget_ptr));
GtkWidget *wrapper = gtk_widget_get_parent(widget);
return gtk_widget_has_focus(widget) || gtk_widget_has_focus(wrapper);
}