Android實(shí)現(xiàn)登錄郵箱的自動(dòng)補(bǔ)全功能
本文實(shí)例為大家分享了Android登錄郵箱自動(dòng)補(bǔ)全功能的實(shí)現(xiàn)方法,供大家參考,具體內(nèi)容如下
效果:

實(shí)現(xiàn)原理:
1、繼承重寫(xiě)簡(jiǎn)單控件AutoCompleteTextView
2、編寫(xiě)自定義數(shù)據(jù)適配器和布局文件,并實(shí)現(xiàn)文字變化監(jiān)聽(tīng)器
3、通過(guò)組合方式,實(shí)現(xiàn)右側(cè)的刪除圖標(biāo)。并根據(jù)焦點(diǎn)和文字的變化,動(dòng)態(tài)顯示右側(cè)刪除圖標(biāo)。
1、通過(guò)繼承自簡(jiǎn)單控件AutoCompleteTextView實(shí)現(xiàn)帳號(hào)自動(dòng)補(bǔ)全
關(guān)鍵代碼:
public class AutoComplete extends AutoCompleteTextView {
private static final String[] emailSuffix = {
"@qq.com", "@163.com", "@126.com", "@gmail.com", "@sina.com", "@hotmail.com",
"@yahoo.cn", "@sohu.com", "@foxmail.com", "@139.com", "@yeah.net", "@vip.qq.com",
"@vip.sina.com"};
......省略號(hào)......
//構(gòu)造函數(shù)原型要正確,留給系統(tǒng)調(diào)用
public AutoComplete(Context context) {
super(context);
mContext = context;
}
public AutoComplete(Context context, AttributeSet attrs) {
super(context, attrs);
mContext = context;
}
public void init(ImageView imageView) {
mImageView = imageView;
final MyAdatper adapter = new MyAdatper(mContext);
setAdapter(adapter);
addTextChangedListener(new TextWatcher() {
@Override
public void afterTextChanged(Editable s) {
if (isTextWatch) {
String input = s.toString();
......省略號(hào)......
adapter.clearList(); //注意要清空數(shù)據(jù),根據(jù)輸入的變化,自動(dòng)生成數(shù)據(jù)
if (input.length() > 0) {
for (int i = 0; i < emailSuffix.length; ++i) {
adapter.addListData(input + emailSuffix[i]);
}
}
adapter.notifyDataSetChanged();
showDropDown();//該行代碼會(huì)造成崩潰
}
}
});
//當(dāng)輸入一個(gè)字符的時(shí)候就開(kāi)始檢測(cè)
setThreshold(1);
}
private class ViewHolder {
TextView tv_Text;
}
class MyAdatper extends BaseAdapter implements Filterable {
private List<String> mList;
private Context mContext;
private MyFilter mFilter;
......省略號(hào)......
public void clearList() {
mList.clear();
}
public void addListData(String strData) {
mList.add(strData);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view;
ViewHolder viewHolder;
if (convertView == null) {
view = LayoutInflater.from(mContext).inflate(R.layout.activity_autocomplete_item, null);
viewHolder = new ViewHolder();
viewHolder.tv_Text = (TextView) view.findViewById(R.id.tv_autocomplete);
view.setTag(viewHolder);
} else {
view = convertView;
viewHolder = (ViewHolder) view.getTag();
}
viewHolder.tv_Text.setText(mList.get(position));
return view;
}
......省略號(hào)......
}
activity_autocomplete_item 下拉列表布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:background="@color/White"
android:layout_height="wrap_content">
<TextView
android:id="@+id/tv_autocomplete"
android:padding="15dp"
android:textSize="20sp"
android:singleLine="true"
android:textColor="@color/Black"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
上面自動(dòng)補(bǔ)全的效果圖:

2、通過(guò)組合方式實(shí)現(xiàn)帳號(hào)自動(dòng)補(bǔ)全復(fù)雜控件
關(guān)鍵代碼:
public class AdvancedAutoCompleteTextView extends RelativeLayout {
private Context mContext;
private AutoComplete mAutoComplete; //上面的自定義控件
private ImageView mImageView; //右側(cè)的圖標(biāo)控件
......省略號(hào)......
@Override
protected void onFinishInflate() {
super.onFinishInflate();
initViews();
}
//代碼方式,初始化布局
private void initViews() {
RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);
params.addRule(RelativeLayout.ALIGN_PARENT_LEFT);
params.addRule(RelativeLayout.CENTER_VERTICAL);
mAutoComplete = new AutoComplete(mContext);
mAutoComplete.setLayoutParams(params);
mAutoComplete.setPadding(0, 0, 40, 0);
mAutoComplete.setSingleLine(true);
mAutoComplete.setInputType(InputType.TYPE_TEXT_VARIATION_EMAIL_ADDRESS);
mAutoComplete.setFitsSystemWindows(true);
mAutoComplete.setEms(10);
mAutoComplete.setHint("URS賬號(hào)");
mAutoComplete.setImeOptions(EditorInfo.IME_ACTION_NEXT
| EditorInfo.IME_FLAG_NO_EXTRACT_UI | EditorInfo.IME_FLAG_NO_FULLSCREEN);
mAutoComplete.setDropDownHorizontalOffset(0);
mAutoComplete.setDropDownVerticalOffset(2);
mAutoComplete.setBackgroundResource(R.drawable.edit_text_background);
RelativeLayout.LayoutParams p = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.WRAP_CONTENT, LayoutParams.FILL_PARENT);
p.addRule(RelativeLayout.ALIGN_PARENT_RIGHT);
p.addRule(RelativeLayout.CENTER_VERTICAL);
p.rightMargin = 10;
mImageView = new ImageView(mContext);
mImageView.setLayoutParams(p);
mImageView.setScaleType(ImageView.ScaleType.FIT_CENTER);
mImageView.setImageResource(R.drawable.unselect);
mImageView.setClickable(true);
mImageView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
setText("");
}
});
this.addView(mAutoComplete);
this.addView(mImageView);
//監(jiān)聽(tīng)獲取焦點(diǎn)事件,目的:輸入帳號(hào)時(shí),右側(cè)圖標(biāo)的顯示
mAutoComplete.setOnFocusChangeListener(new OnFocusChangeListener() {
@Override
public void onFocusChange(View v, boolean hasFocus) {
if (hasFocus && !mAutoComplete.getText().toString().isEmpty()) {
mAutoComplete.setShow(false); //如果獲取首次獲取焦點(diǎn),此時(shí)文本不為空,則顯示,并禁止文本改變監(jiān)聽(tīng)里的設(shè)置
mImageView.setImageResource(R.drawable.item_delete);
} else if (hasFocus) {
mAutoComplete.setShow(true);//如果獲取首次獲取焦點(diǎn),此時(shí)文本為空,則不改變,并開(kāi)啟文本改變監(jiān)聽(tīng)里的設(shè)置
} else {
mAutoComplete.setShow(false);
mImageView.setImageResource(R.drawable.unselect);
}
}
});
//對(duì)AutoComplete自定義控件初始化,一定要放到最后.否則,會(huì)由于AutoComplete初始化未完成,就彈窗,而崩潰
mAutoComplete.init(mImageView);
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
- Android 自動(dòng)補(bǔ)全提示輸入AutoCompleteTextView、 MultiAutoCompleteTextView
- 實(shí)例講解Android中的AutoCompleteTextView自動(dòng)補(bǔ)全組件
- Android中EditText和AutoCompleteTextView設(shè)置文字選中顏色方法
- Android中AutoCompleteTextView與MultiAutoCompleteTextView的用法
- Android AutoCompleteTextView控件使用實(shí)例
- 基于Android中的 AutoCompleteTextView實(shí)現(xiàn)自動(dòng)填充
- Android AutoCompleteTextView連接數(shù)據(jù)庫(kù)自動(dòng)提示的方法(附demo源碼下載)
- Android AutoCompleteTextView自動(dòng)提示文本框?qū)嵗a
- Android仿百度谷歌搜索自動(dòng)提示框AutoCompleteTextView簡(jiǎn)單應(yīng)用示例
- Android用戶輸入自動(dòng)提示控件AutoCompleteTextView使用方法
相關(guān)文章
Android靜默安裝實(shí)現(xiàn)方案 仿360手機(jī)助手秒裝和智能安裝功能
這篇文章主要介紹了Android靜默安裝實(shí)現(xiàn)方案,仿360手機(jī)助手秒裝和智能安裝功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11
詳解Android中用于線程處理的AsyncTask類的用法及源碼
這篇文章主要介紹了Android中用于線程處理的AsyncTask類的用法及源碼,講到了實(shí)現(xiàn)AsyncTask中所用到的Handler及線程池等要點(diǎn),需要的朋友可以參考下2016-05-05
Android編程之SMS讀取短信并保存到SQLite的方法
這篇文章主要介紹了Android編程之SMS讀取短信并保存到SQLite的方法,涉及Android針對(duì)SMS短信及SQLite數(shù)據(jù)庫(kù)的相關(guān)操作技巧,需要的朋友可以參考下2015-11-11
Android 深入探究自定義view之事件的分發(fā)機(jī)制與處理詳解
對(duì)于安卓程序員來(lái)說(shuō),自定義view簡(jiǎn)直不要太重要,畢竟有很多功能,譬如圓形頭像這些,用單純的原生非常難以實(shí)現(xiàn),而用自定義view,簡(jiǎn)直分分鐘2021-11-11
Android自定義view實(shí)現(xiàn)圓形waveview
這篇文章主要為大家詳細(xì)介紹了Android自定義view實(shí)現(xiàn)圓形waveview,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01
Android中自定義PopupWindow實(shí)現(xiàn)彈出框并帶有動(dòng)畫(huà)效果
這篇文章主要介紹了Android中自定義PopupWindow實(shí)現(xiàn)彈出框并帶有動(dòng)畫(huà)效果的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
Android編程顯示網(wǎng)絡(luò)上的圖片實(shí)例詳解
這篇文章主要介紹了Android編程顯示網(wǎng)絡(luò)上的圖片,結(jié)合實(shí)例形式詳細(xì)分析了Android顯示網(wǎng)絡(luò)圖片的流程與具體操作技巧,需要的朋友可以參考下2016-10-10
Android中l(wèi)istview嵌套scrollveiw沖突的解決方法
這篇文章主要為大家詳細(xì)介紹了Android中l(wèi)istview嵌套scrollveiw沖突的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01

