您好,登錄后才能下訂單哦!
前言
Android的編輯框控件EditText在平常編程時會經常用到,有時候會對編輯框增加某些限制,如限制只能輸入數字,最大輸入的文字個數,不能輸入一些非法字符等,本文就來給大家介紹了一種最簡單的輸入限制方法。
效果圖
Github地址,歡迎點贊,fork
今天帶來工作中的一個小安利,產品要求對用戶名輸入需要限制,只能是數字和字母,符號,不能包含空格和鍵盤上輸入的emoji.開始拿到這個需求,覺得給 EditText 增加一個 addTextChangedListener ,里面做各種判斷不就OK 啦!
哈哈,又可以愉快的玩耍咯...
但是回調里面邏輯太多,看著也不爽,不符合我們程序員的氣質,簡潔大方,干凈利落!所以我特意去看了 du 了一下, 結合自己的實際要求,重寫了 EditText 的 onCreateInputConnection() 方法,在那里做文章,請看下面源碼(如果還有不清楚的,可以留言或者看Github地址)
方法如下:
只需要自定義EditText重寫其onCreateInputConnection()方法,然后再定義一個內部類就好,下面代碼即拷即用
首先,看看 LimitEditText
class LimitEditText(context: Context, attrs: AttributeSet, defStyleAttr: Int) : EditText(context, attrs, defStyleAttr) { constructor(context: Context, attrs: AttributeSet) : this(context, attrs, 0) /** * 輸入法 */ override fun onCreateInputConnection(outAttrs: EditorInfo?): InputConnection { return InnerInputConnection(super.onCreateInputConnection(outAttrs), false) } } class InnerInputConnection(target: InputConnection, mutable: Boolean) : InputConnectionWrapper(target, mutable) { // 數字,字母 private val pattern = Pattern.compile("^[0-9A-Za-z_]\$") // 標點 private val patternChar = Pattern.compile("[^\\w\\s]+") // EmoJi private val patternEmoJi = Pattern.compile("[\ud83c\udc00-\ud83c\udfff]|[\ud83d\udc00-\ud83d\udfff]|[\u2600-\u27ff]", Pattern.UNICODE_CASE or Pattern.CASE_INSENSITIVE) // 英文標點 private val patternEn = Pattern.compile("^[`~!@#\$%^&*()_\\-+=<>?:\"{},.\\\\/;'\\[\\]]\$") // 中文標點 private val patternCn = Pattern.compile("^[·!#¥(——):;“”‘、,|《。》?、【】\\[\\]]\$") // 對輸入攔截 override fun commitText(text: CharSequence?, newCursorPosition: Int): Boolean { if (patternEmoJi.matcher(text).find()){ return false } if (pattern.matcher(text).matches() || patternChar.matcher(text).matches()) { return super.commitText(text, newCursorPosition) } return false } }
總計60行代碼,可以搞定一般需求啦,再來看看其布局用法(xml文件),平時怎么在布局寫EditText,還是怎么寫!
<?xml version="1.0" encoding="utf-8"?> <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="cn.molue.jooyer.limitedittext.MainActivity"> <cn.molue.jooyer.limitedittext.LimitEditText android:id="@+id/let_main" android:layout_width="match_parent" android:layout_height="50dp" android:layout_margin="10dp" android:text="Hello World!" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toTopOf="parent"/> </android.support.constraint.ConstraintLayout>
最后來看看在 Activity 中用法,其實和一般普通 EditText 用法一致啦!
class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) // demo 中默認 LimitEditText 只能輸入字母數字和標點符號 // 延時主要是更方便觀察 window.decorView.postDelayed({ // 注意,獲得焦點需要自己再處理下,其實很簡單,如下: let_main.isFocusable = true let_main.isFocusableInTouchMode = true let_main.requestFocus() },1000) } }
當然,這些限制正則也可以在 LimitEditText 中定義方法,大家需要什么加入什么就好了!
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。