Android开发Android知识Android技术知识

Android 软键盘监听回车之没辣么简单

2017-07-21  本文已影响1136人  卡路fly

1. imeOptions

<EditText android:imeOptions="actionSend"/> 
                 或
mEditText.setImeOptions(EditorInfo.IME_ACTION_SEND);   

2. setOnKeyListener

chatEditContent.setOnKeyListener(new View.OnKeyListener() {
   @Override
   public boolean onKey(View v, int keyCode, KeyEvent event) {
       if (event != null && KeyEvent.KEYCODE_ENTER == keyCode && KeyEvent.ACTION_DOWN == event.getAction()) {
           // 此处来点freestyle~
           return true;
       }
       return false;
   }
});

3. dispatchKeyEvent

@Override
public boolean dispatchKeyEvent(KeyEvent event) {
    
   if (isPressEnterSendMsg && event.getAction() == KeyEvent.ACTION_DOWN &&
           event.getKeyCode() == KeyEvent.KEYCODE_ENTER) {
       // 此处来点freestyle~
       return true;
   }
    return super.dispatchKeyEvent(event);
}

4. onEditorAction (点赞)

chatEditContent.setOnEditorActionListener(new TextView.OnEditorActionListener() {

   @Override
   public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
       if (actionId == EditorInfo.IME_ACTION_SEND
               || actionId == EditorInfo.IME_ACTION_DONE
               || (event != null && KeyEvent.KEYCODE_ENTER == event.getKeyCode() && KeyEvent.ACTION_DOWN == event.getAction())) {
           // 此处来点freestyle~
       }
       return true;
   }
});

等等,这些方法已经被用烂了:)

为啥还写 🤔

此处,需要一条分割线……

在实际操作的过程中,还是遇到了一个很头疼的问题 😤

华为输入法!触宝输入法!😫

并!

不能!

很生气有木有!

所以!👀

终极版(TextWatcher)

chatEditContent.addTextChangedListener(new TextWatcher() {
    @Override
    public void beforeTextChanged(CharSequence s, int start, int count, int after) {

    }

    @Override
    public void onTextChanged(CharSequence s, int start, int before, int count) {
            if (s == null)
                return;
            String str = s.toString().substring(start, start + count);
            if (str.equals("\n")) {
                chatEditContent.setText(s.toString().replaceFirst("\n", ""));
               
                // 此处来点freestyle~
                
                return;
            }
    }

    @Override
    public void afterTextChanged(Editable s) {

    }
});

抱抱TextWatcher 🤗 啊哈哈哈哈,我们看看官方介绍:

When an object of a type is attached to an Editable, its methods will be called when the text is changed.


不得不说,TextWatcher 干的漂亮~


上回书说到回车监听的第四种方法……
很快就遇到了新问题,不知列位看官有没有发现,我们在上面的onTextChanged方法中进行了setText!本来是没啥问题的,但是个别地方遇到SpannableString就出了问题……

于是乎,我尝试了各种办法,看到回车都想吐了好吗:)
看到很多人遇到这个问题就是没有解决的办法
我也很绝望啊,症状完全相符合有木有啊!
就是没人回答。

原因EditText的inputType为textMultiLine和部分输入法的回车监听相冲突!
妈蛋,终于找到病根了……

当EditText的inputType包含textMultiLine标志位,会强迫imeOptions加上IME_FLAG_NO_ENTER_ACTION位,这导致了只显示Enter键。

因此,对EditText进行如下修改,这个办法真的是让老夫哇的一声哭出来……

public class ChatEditText extends EditText {

    public ChatEditText(Context context) {
        super(context);
    }

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

    public ChatEditText(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    @Override
    public InputConnection onCreateInputConnection(EditorInfo outAttrs) {
        InputConnection connection = super.onCreateInputConnection(outAttrs);
        int imeActions = outAttrs.imeOptions & EditorInfo.IME_MASK_ACTION;
        if ((imeActions & EditorInfo.IME_ACTION_SEND) != 0) {
            outAttrs.imeOptions ^= imeActions;
            outAttrs.imeOptions |= EditorInfo.IME_ACTION_SEND;
        }
        if ((outAttrs.imeOptions & EditorInfo.IME_FLAG_NO_ENTER_ACTION) != 0) {
            outAttrs.imeOptions &= ~EditorInfo.IME_FLAG_NO_ENTER_ACTION;
        }
        return connection;
    }
}

配合使用上面的onEditorAction,效果更佳啊哈哈哈哈

送个小礼包:在测试的过程中,触宝输入法还是不能被监听,经过修改


android:inputType="textShortMessage|textAutoCorrect|textCapSentences|textMultiLine"

去掉textShortMessage                            

android:inputType="textAutoCorrect|textCapSentences|textMultiLine"

以上就是我知道的所有方法啊哈哈哈

应该还有其他的

求分享啊哈哈😉

上一篇下一篇

猜你喜欢

热点阅读