Android 完美實現(xiàn)手機號344格式化效果

一、前言:

在展示手機號碼的時候,會遇到手機號按照344格式效果,這種效果的實現(xiàn)遇到過兩次了,也踩過了許多的坑,在這里記錄一下一個完美實現(xiàn)這種效果的方式。輸入、插入、刪除等光標位置停留比較好的交互效果。

二、效果:

捕獲.PNG

三、代碼:

public class ZpPhoneEditText extends AppCompatEditText implements TextWatcher {  
  
    // 特殊下標位置  
    private static final int PHONE_INDEX_3 = 3;  
    private static final int PHONE_INDEX_4 = 4;  
    private static final int PHONE_INDEX_8 = 8;  
    private static final int PHONE_INDEX_9 = 9;  
  
    public ZpPhoneEditText(Context context) {  
        super(context);  
        initView();
    }  
  
    public ZpPhoneEditText(Context context, AttributeSet attrs) {  
        super(context, attrs);  
        initView();
    }  
  
    public ZpPhoneEditText(Context context, AttributeSet attrs, int defStyleAttr) {  
        super(context, attrs, defStyleAttr);  
        initView();
    }  

    private void initView() {
        setFilters(new InputFilter[]{
                new InputFilter() {
                    @Override
                    public CharSequence filter(CharSequence source, int start, int end, 
                                                Spanned spanned, int dstart, int dend) {
                        boolean canInput = (source.length() + (TextUtils.isEmpty(spanned) ? 0 : spanned.length())) <= 13;
                        if (" ".equals(source.toString()) || source.toString().contentEquals("\n") || !canInput) {
                            return "";
                        } else {
                            return null;
                        }
                    }
                }
        });
    }
  
    @Override  
    public void beforeTextChanged(CharSequence s, int start, int count, int after) {  
  
    }  
  
    @Override  
    public void onTextChanged(CharSequence s, int start, int before, int count) {  
        super.onTextChanged(s, start, before, count);  
        if (s == null || s.length() == 0) {  
            return;  
        }  
        StringBuilder sb = new StringBuilder();  
        for (int i = 0; i < s.length(); i++) {  
            if (i != PHONE_INDEX_3 && i != PHONE_INDEX_8 && s.charAt(i) == ' ') {  
                continue;  
            } else {  
                sb.append(s.charAt(i));  
                if ((sb.length() == PHONE_INDEX_4 || sb.length() == PHONE_INDEX_9) && sb.charAt(sb.length() - 1) != ' ') {  
                    sb.insert(sb.length() - 1, ' ');  
                }  
            }  
        }  
        if (!sb.toString().equals(s.toString())) {  
            int index = start + 1;  
            if (sb.charAt(start) == ' ') {  
                if (before == 0) {  
                    index++;  
                } else {  
                    index--;  
                }  
            } else {  
                if (before == 1) {  
                    index--;  
                }  
            }  
  
            setText(sb.toString());  
            setSelection(index);  
        }  
    }  
  
    @Override  
    public void afterTextChanged(Editable s) {  
  
    }  
  
    // 獲得不包含空格的手機號  
    public String getPhoneText() {  
        String str = getText().toString();  
        return replaceBlank(str);  
    }  
  
    private String replaceBlank(String str) {  
        String dest = "";  
        if (str != null) {  
            Pattern p = Pattern.compile("\\s*|\t|\r|\n");  
            Matcher m = p.matcher(str);  
            if (m.find()) {  
                dest = m.replaceAll("");  
            }  
        }  
        return dest;  
    }  
}  

布局XML

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"  
    android:gravity="center"  
    android:orientation="vertical">  
  
    <com.example.zpdemo.widget.ZpPhoneEditText  
        android:id="@+id/et_phone"  
        android:layout_width="300dp"  
        android:layout_height="wrap_content"  
        android:hint="格式化手機號344"  
        android:inputType="phone"  
        android:maxLength="13"/>  
  
    <Button  
        android:id="@+id/btn_phone"  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:layout_marginTop="20dp"  
        android:textColor="#f00"  
        android:textSize="16sp"  
        android:text="獲得手機號"/>  
  
</LinearLayout>  

應(yīng)用

private ZpPhoneEditText etPhone;  
    private Button btnPhone;  
  
    private void initView() {  
        etPhone = (ZpPhoneEditText) findViewById(R.id.et_phone);  
        btnPhone = (Button) findViewById(R.id.btn_phone);  
        btnPhone.setOnClickListener(new View.OnClickListener() {  
  
            @Override  
            public void onClick(View v) {  
                btnPhone.setText(etPhone.getPhoneText());  
            }  
     });  
} 

效果杠杠的,代碼比較完整,親自嘗試一下比較好。。。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,119評論 25 708
  • 哈里王子和非裔美籍演員梅根馬克爾訂婚了。王妃的誕生源于王子在合適的時候找到合適他的人。這樣的人怎么出現(xiàn)的呢? ...
    悅歷_77c7閱讀 498評論 1 0
  • 來了學??煲粋€學期,由于身邊有一臺打印機,我有了學習使用打印機的機會,確實,我也學到了點東西。但是打印的相關(guān)知識仍...
    小斌PPT閱讀 544評論 0 3
  • 五一的車站人頭攢動,剛剛倒車來到某車站回京,看到一排有兩個位置,其中一個和我年紀相仿的女子在低頭看手機,我上去輕輕...
    怪異的kinn閱讀 456評論 0 1

友情鏈接更多精彩內(nèi)容