Android 自定义EditText禁止输入表情

废话不多说,直接上代码:

下面是自定义控件的全部代码

import android.content.Context;
import android.text.Editable;
import android.text.Selection;
import android.text.Spannable;
import android.text.TextWatcher;
import android.util.AttributeSet;
import android.widget.EditText;
import android.widget.Toast;

/**
 * Created by dell on 2018/6/15.
 */

public class EmojiEditText extends EditText {

    // 输入表情前的光标位置
    private int cursorPos; // 输入表情前EditText中的文本
    private String inputAfterText; // 是否重置了EditText的内容
    private boolean resetText;
    private Context mContext;


    public EmojiEditText(Context context) {
        super(context);
        this.mContext = context;
        initEditText();
    }


    public EmojiEditText(Context context, AttributeSet attrs) {
        super(context, attrs);
        this.mContext = context;
        initEditText();
    }


    public EmojiEditText(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;
//暂不支持输入Emoji表情符号
                            Toast.makeText(mContext, "暂不支持输入表情符号", Toast.LENGTH_SHORT).show(); // 是表情符号就将文本还原为输入表情符号之前的内容
                            setText(inputAfterText);
                            CharSequence text = getText();
                            if (text instanceof Spannable) {
                                Spannable spanText = (Spannable) text;
                                Selection.setSelection(spanText, text.length());
                            }
                        }
                    }
                } 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.widget.EmojiEditText
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="请输入"
    android:paddingLeft="28dp"
    android:background="@color/colorAccent"
    android:textColor="@color/font_color_gray"
    android:textSize="13dp"
    android:minLines="4"
    android:gravity="left|top"
    android:paddingTop="8dp"
    android:cursorVisible="true"
    android:textCursorDrawable="@drawable/test_cursor_shape"    //给EditText设置光标
    />
 

设置光标的xml样式

<shape xmlns:android="http://schemas.android.com/apk/res/android"
        android:shape="rectangle">

        <size android:width="1dp" />

        <span style="font-family: Arial, Helvetica, sans-serif;"><!-- 光标宽度可以自己定义 --></span>

        <solid android:color="@color/textview_text_color" /><!-- 光标颜色可以自己定义 -->
</shape>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值