Android 優雅的實現通用格式化編輯
格式化編輯的需求一般是從編輯手機號開始的,UI 給出的效果不是11個連續的數字,而是采用3、4、4的形式,每段中間會空一個字符。在技術實現的時候,一般會自定義一個控件 TelEditText 實現功能,隨著項目迭代,格式化編輯的需求可能會增加,比如說身份證號、自定義的優惠券碼等,這個時候再給每種情況自定義一個控件就沒必要了,通過一個控件實現多種格式化編輯需求是更好的方案。
其實還可以更進一步,格式化編輯的核心邏輯就是給 EditText 添加一個 TextWatcher,通過 TextWatcher 中的文本變化回調來調整 EditText 中的文本,所以自定義 EditText 并不是必須的,對于開發者需要調用的字段和方法,可以通過擴展函數的方式提供。
使用格式化編輯手機號布局:
<androidx.appcompat.widget.AppCompatEditText android: android:layout_width='match_parent' android:layout_height='wrap_content' android:inputType='number' />
代碼:
// format is ’ ’etPhone.setFormatRules(3, 4, 4)// format is ’-’etPhone.setFormatRules(3, 4, 4, formatChar = ’-’)
布局:
<androidx.appcompat.widget.AppCompatEditText android: android:layout_width='match_parent' android:layout_height='wrap_content' android:digits='@string/digits_id_number'/>
資源:
<string name='digits_id_number'>0123456789xX</string>
代碼:
etIDNumber.setFormatRules(6, 4, 4, 4)
etPhone.setOnFormatEditListener { isComplete, text -> if (isComplete) { // 編輯完成 // 使用 toast 顯示移除格式化的文本 Toast.makeText(this, text, Toast.LENGTH_SHORT).show() }}移除格式化的文本
etPhone.textWithFormatRemoved實現原理
自定義一個 TextWatcher,定義一個字段 formatChar,值為格式化字符,默認是空格。定義一個字段 formatCharIndexList,值為 EditText 文本中格式化字符所在位置的列表,比如對于格式化編輯手機號, formatCharIndexList 中的值為 [3, 8],既在 EditText 文本中格式化字符的位置應該是3和8。
var formatChar: Char = ’ ’val formatCharIndexList = ArrayList<Int>()
EditText 文本發生變化后,如果 EditText 文本的最后一個字符為格式化字符,則刪除最后一個字符;然后遍歷 EditText 文本中的每一個字符,如果該字符的位置等于格式化字符位置但不是格式化字符,則在該位置插入一個格式化字符,如果該字符的位置不等于格式化字符的位置但又是格式化字符,則刪除該格式化字符。
調用 insertFormatChar 或者 deleteChar 后,afterTextChanged 又會立即回調一次,可能會引起多次添加或刪除,導致格式化錯誤。所以每次 afterTextChanged 回調最多進行一次操作,如果后續還需要操作,放在下一次 afterTextChanged 回調中進行。
override fun afterTextChanged(s: Editable?) { val value = s?.toString() ?: return if (value.isEmpty()) return if (value.last() == formatChar) { deleteChar(s, value.lastIndex) return } value.forEachIndexed { index, c -> if (formatCharIndexList.contains(index)) { if (c != formatChar) { insertFormatChar(s, index) return } } else { if (c == formatChar) { deleteChar(s, index) return } } } ...}項目地址
format-edit,覺得用起來很爽的,請不要吝嗇你的 Star !
以上就是Android 優雅的實現通用格式化編輯的詳細內容,更多關于Android 通用格式化編輯的資料請關注好吧啦網其它相關文章!
相關文章: