You've already forked android_translation_layer
mirror of
https://gitlab.com/android_translation_layer/android_translation_layer.git
synced 2025-10-27 11:48:10 -07:00
implement EditText.setOnEditorActionListener()
This makes the NewPipe search work again
This commit is contained in:
@@ -49,3 +49,31 @@ JNIEXPORT void JNICALL Java_android_widget_EditText_native_1addTextChangedListen
|
||||
|
||||
g_signal_connect(GTK_EDITABLE(entry), "changed", G_CALLBACK(changed_cb), callback_data);
|
||||
}
|
||||
|
||||
#define IME_ACTION_SEARCH 3
|
||||
#define KEYCODE_ENTER 66
|
||||
|
||||
static void on_activate(GtkEntry *entry, struct changed_callback_data *d)
|
||||
{
|
||||
JNIEnv *env = get_jni_env();
|
||||
|
||||
jobject key_event = (*env)->NewObject(env, handle_cache.key_event.class, handle_cache.key_event.constructor, IME_ACTION_SEARCH, KEYCODE_ENTER);
|
||||
(*env)->CallBooleanMethod(env, d->listener, d->listener_method, d->this, 0, key_event);
|
||||
if((*env)->ExceptionCheck(env))
|
||||
(*env)->ExceptionDescribe(env);
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_android_widget_EditText_native_1setOnEditorActionListener(JNIEnv *env, jobject this, jlong widget_ptr, jobject listener)
|
||||
{
|
||||
GtkEntry *entry = GTK_ENTRY(_PTR(widget_ptr));
|
||||
|
||||
if (!listener)
|
||||
return;
|
||||
|
||||
struct changed_callback_data *callback_data = malloc(sizeof(struct changed_callback_data));
|
||||
callback_data->this = _REF(this);
|
||||
callback_data->listener = _REF(listener);
|
||||
callback_data->listener_method = _METHOD(_CLASS(listener), "onEditorAction", "(Landroid/widget/TextView;ILandroid/view/KeyEvent;)Z");
|
||||
|
||||
g_signal_connect(entry, "activate", G_CALLBACK(on_activate), callback_data);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user