溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android最簡單的限制輸入方法(只包含數(shù)字、字母和符號)

發(fā)布時間:2020-10-15 06:08:07 來源:腳本之家 閱讀:534 作者:天星技術(shù)團(tuán)隊 欄目:移動開發(fā)

前言

Android的編輯框控件EditText在平常編程時會經(jīng)常用到,有時候會對編輯框增加某些限制,如限制只能輸入數(shù)字,最大輸入的文字個數(shù),不能輸入一些非法字符等,本文就來給大家介紹了一種最簡單的輸入限制方法。

效果圖

Android最簡單的限制輸入方法(只包含數(shù)字、字母和符號)

Github地址,歡迎點贊,fork

今天帶來工作中的一個小安利,產(chǎn)品要求對用戶名輸入需要限制,只能是數(shù)字和字母,符號,不能包含空格和鍵盤上輸入的emoji.開始拿到這個需求,覺得給 EditText 增加一個 addTextChangedListener ,里面做各種判斷不就OK 啦!

哈哈,又可以愉快的玩耍咯...

但是回調(diào)里面邏輯太多,看著也不爽,不符合我們程序員的氣質(zhì),簡潔大方,干凈利落!所以我特意去看了 du 了一下, 結(jié)合自己的實際要求,重寫了 EditText  的 onCreateInputConnection() 方法,在那里做文章,請看下面源碼(如果還有不清楚的,可以留言或者看Github地址)

方法如下:

只需要自定義EditText重寫其onCreateInputConnection()方法,然后再定義一個內(nèi)部類就好,下面代碼即拷即用

首先,看看 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) {
 // 數(shù)字,字母
 private val pattern = Pattern.compile("^[0-9A-Za-z_]\$")
 // 標(biāo)點
 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)
 // 英文標(biāo)點
 private val patternEn = Pattern.compile("^[`~!@#\$%^&*()_\\-+=<>?:\"{},.\\\\/;'\\[\\]]\$")
 // 中文標(biāo)點
 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 中默認(rèn) LimitEditText 只能輸入字母數(shù)字和標(biāo)點符號

  // 延時主要是更方便觀察
  window.decorView.postDelayed({
   // 注意,獲得焦點需要自己再處理下,其實很簡單,如下:
   let_main.isFocusable = true
   let_main.isFocusableInTouchMode = true
   let_main.requestFocus()

  },1000)
 }
}

當(dāng)然,這些限制正則也可以在 LimitEditText 中定義方法,大家需要什么加入什么就好了!

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI