簡體   English   中英

Textinput(React Native - Android) - 支持onKeyPreIme

[英]Textinput (React Native - Android) - Support onKeyPreIme

在本機代碼(java)中,我可以使用handle onKeyPreIme創建TextInput

像這樣

 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
    ...  
  }
}

TextInput做反應原生支持嗎?

感謝您的幫助。

編輯:我的目標是在顯示鍵盤時停止按下。 使用onKeyPreIme可以輕松使用onKeyPreIme 我嘗試使用React原生的@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)
});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM