android 输入框EditText禁止输入Emoji表情符
2015-09-11 09:31
316 查看
通过添加EditText的addTextChangedListener()监听来过滤Emoji表情:
onTextChanged()
beforeTextChanged()
使用方法
在开发中可能多处会用到过滤Emoji表情符,为了方便使用自定义EditText来实现:
![](http://img.blog.csdn.net/20150911093237782?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
![](http://img.blog.csdn.net/20150911093255869?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
xml文件使用方法
不过我这边用的是魅族的输入法,发现它默认的输入法在输入时会发现越界错误,如果大家有什么好的修改建议,就提出来,同时欢迎大家探讨。
onTextChanged()
beforeTextChanged()
使用方法
在开发中可能多处会用到过滤Emoji表情符,为了方便使用自定义EditText来实现:
import android.widget.EditText; import android.widget.Toast; import android.content.Context; import android.text.Editable; import android.text.Selection; import android.text.Spannable; import android.text.TextWatcher; import android.util.AttributeSet; public class ContainsEmojiEditText extends EditText { //输入表情前的光标位置 private int cursorPos; //输入表情前EditText中的文本 private String inputAfterText; //是否重置了EditText的内容 private boolean resetText; private Context mContext; public ContainsEmojiEditText(Context context) { super(context); this.mContext = context; initEditText(); } public ContainsEmojiEditText(Context context, AttributeSet attrs) { super(context, attrs); this.mContext = context; initEditText(); } public ContainsEmojiEditText(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); this.mContext = context; initEditText(); } // 初始化edittext 控件 private void initEditText() { addTextChangedListener(new TextWatcher() { @Override public void beforeTextChanged(CharSequence s, int start, int before, int count) { if (!resetText) { cursorPos = getSelectionEnd(); // 这里用s.toString()而不直接用s是因为如果用s, // 那么,inputAfterText和s在内存中指向的是同一个地址,s改变了, // inputAfterText也就改变了,那么表情过滤就失败了 inputAfterText= s.toString(); } } @Override public void onTextChanged(CharSequence s, int start, int before, int count) { if (!resetText) { if (count >= 2) {//表情符号的字符长度最小为2 CharSequence input = s.subSequence(cursorPos, cursorPos + count); if (containsEmoji(input.toString())) { resetText = true; Toast.makeText(mContext, "不支持输入Emoji表情符号", Toast.LENGTH_SHORT).show(); //是表情符号就将文本还原为输入表情符号之前的内容 setText(inputAfterText); CharSequence text = getText(); if (text instanceof Spannable) { Spannable spanText = (Spannable) text; Selection.setSelection(spanText, text.length()-1); } } } } else { resetText = false; } } @Override public void afterTextChanged(Editable editable) { } }); } /** * 检测是否有emoji表情 * * @param source * @return */ public static boolean containsEmoji(String source) { int len = source.length(); for (int i = 0; i < len; i++) { char codePoint = source.charAt(i); if (!isEmojiCharacter(codePoint)) { //如果不能匹配,则该字符是Emoji表情 return true; } } return false; } /** * 判断是否是Emoji * * @param codePoint 比较的单个字符 * @return */ private static boolean isEmojiCharacter(char codePoint) { return (codePoint == 0x0) || (codePoint == 0x9) || (codePoint == 0xA) || (codePoint == 0xD) || ((codePoint >= 0x20) && (codePoint <= 0xD7FF)) || ((codePoint >= 0xE000) && (codePoint <= 0xFFFD)) || ((codePoint >= 0x10000) && (codePoint <= 0x10FFFF)); } }
xml文件使用方法
<com.liujy.ui.wiget.ContainsEmojiEditText android:layout_width="match_parent" android:layout_height="wrap_content" />
不过我这边用的是魅族的输入法,发现它默认的输入法在输入时会发现越界错误,如果大家有什么好的修改建议,就提出来,同时欢迎大家探讨。
相关文章推荐
- Android实现推送方式解决方案
- Android 编程下 Touch 事件的分发和消费机制
- Android(java)的线程池:ExecutorService和Executors简单介绍
- 关于Android屏幕适配
- android 把图片状态由彩色变成灰色
- Androidz之clickable
- Xamarin.Android使用教程之简介和安装
- 解读Android之Service(3)AIDL
- 利用Android的SDK工具来做应用程序测试
- Android 转场动画 windowAnimation和ActivityAnimation的区别
- Android 学习第12课,应用出错信息
- 解放程序猿宝贵的右手(或者是左手) ——Android自动化测试技巧
- Android studio听云接入另外一种方式
- Android(java)学习笔记226:服务(service)之为什么使用服务
- android 菜单介绍
- Android ADB命令
- 启动android 虚拟机提示内存错误的解决办法
- 设置Activity的显示位置
- AndroidManifest.xml文件的作用和简单使用
- android常见错误之 No resource found that matches the given name