Android 完美實現手機號344格式化效果
一、前言:
在展示手機號碼的時候,會遇到手機號按照344格式效果,這種效果的實現遇到過兩次了,也踩過了許多的坑,在這裡記錄一下一個完美實現這種效果的方式。輸入、插入、刪除等游標位置停留比較好的互動效果。
二、效果:
三、程式碼:
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) {
if (" ".equals(source.toString()) || source.toString().contentEquals("\n") || dstart == 13) {
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>
應用
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());
}
});
}
效果槓槓的,程式碼比較完整,親自嘗試一下比較好。。。
相關文章
- android 利用path 實現手寫板的手寫效果Android
- android之實現跳轉手機通訊錄獲取指定姓名和手機號碼Android
- android 獲取手機號碼Android
- oauth 實現手機號碼登入OAuth
- Android實現蛛網背景效果Android
- Java格式化手機號和身份證號,中間使用星號*隱藏Java
- 毛玻璃效果在Android的實現Android
- Android實現輸入手機號時自動新增空格Android
- Android實現Rxjava2+Retrofit完美封裝AndroidRxJava封裝
- 文字印表機 效果實現
- 手機直播原始碼,實現圖片瀑布流式滑動效果原始碼
- CSS + JS 實現打字機效果CSSJS
- 教你如何實現 Android TextView 文字輪播效果AndroidTextView
- Android開發中陰影效果的實現Android
- Abp 實現通過手機號註冊使用者
- [小程式開發實戰]使用WxJava實現手機號獲取Java
- leetcode344 反轉字串 c++實現LeetCode字串C++
- JavaScript實現隨機抽獎效果JavaScript隨機
- 兩臺Linux完美實現雙機熱備Linux
- Android RecyclerView實現頭部懸浮吸頂效果AndroidView
- Android之AppBarLayout實現懸停吸附伸縮效果AndroidAPP
- 直播軟體搭建,Android實現文字滾動播放效果Android
- Laravel 實現使用者名稱 + 郵箱 + 手機號登入Laravel
- Android 實現GridView的橫向滾動,實現仿京東秒殺效果AndroidView
- 小例項: 用vue實現手風琴效果Vue
- 手機直播原始碼,Android studio 實現簡單的視訊播放原始碼Android
- Android-實現記住賬號密碼功能Android密碼
- 短視訊系統,Android 使用MotionLayout實現動畫效果Android動畫
- 給大家分享一段手機號或或者貨幣格式化的程式碼
- 實現聚焦效果
- element-ui table表格元件實現手風琴效果UI元件
- Android手寫籤批功能實現(適配Android6Android
- Android 實現開機自啟APPAndroidAPP
- Android RollBack機制實現原理剖析Android
- 實現 Android 手機上同時安裝正式包和測試包Android
- 序號格式化
- android短影片開發,點選兩次實現不同點選效果的實現方式Android
- 直播系統程式碼,Android自定義View實現呼吸燈效果AndroidView