gpt4 book ai didi

android - Textinput (React Native - Android) - 支持 onKeyPreIme

转载 作者:太空狗 更新时间:2023-10-29 13:48:39 31 4
gpt4 key购买 nike

在 native 代码 (java) 中,我可以创建带有句柄 onKeyPreImeTextInput

像这样

com/myapp/CustomEditText.java
package com.myapp;

import android.content.Context;
import android.util.AttributeSet;
import android.view.KeyEvent;
import android.widget.EditText;

public class CustomEditText extends EditText {

public CustomEditText(Context context, AttributeSet attrs) {
super(context, attrs);
}

@Override
public boolean onKeyPreIme(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
return true;
}
return false;
}
}

xml

// res/layout/activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<com.myapp.CustomEditText
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/someid"
android:layout_height="wrap_content"
android:layout_width="match_parent"
/>

MainActivity.java

// com/myapp/MainActivity.java

package com.myapp;

import android.os.Bundle;
import com.facebook.react.ReactActivity;

public class MainActivity extends ReactActivity {
...
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); //this line test TextInput
...
}
}

React native 是否支持在 TextInput 中执行此操作?

感谢任何帮助。

编辑:我的目标是在显示键盘时停止向后按。使用 onKeyPreIme 在 native 中很容易。我尝试使用 React native 的 @Override onBackPressBackHandler 但也不起作用。

// MainActivity.java

@Override
public void onBackPressed() {
return;
}

此代码在显示键盘时无效。

最佳答案

const blackBack = () => true;

Keyboard.addListener('keyboardDidShow', () => {
BackHandler.addListener('hardwareBackPress', blackBack)
});

Keyboard.addListener('keyboardDidHide', () => {
BackHandler.removeListener('hardwareBackPress', blackBack)
});

关于android - Textinput (React Native - Android) - 支持 onKeyPreIme,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50127094/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com