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"
以上就是我知道的所有方法啊哈哈哈
应该还有其他的
求分享啊哈哈😉