Android自定義輸入框提示功能
本文實(shí)例為大家分享了Android自定義輸入框提示的具體代碼,供大家參考,具體內(nèi)容如下
這是系統(tǒng)提供的一個(gè)控件:AutoCompleteTextView
<AutoCompleteTextView
android:layout_marginLeft="20dp"
android:id="@+id/name_edit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="6"
android:completionThreshold="1"
android:textSize="15sp"
android:maxLength="10"
android:singleLine="true"
android:paddingBottom="4dp"
android:background="@null"
android:hint="請(qǐng)輸入姓名"/>
但是我們想在item的布局中加入其他東西怎么辦?這樣我們只能自己定義適配器,首先先看看AutoCompleteTextView需要的適配器的類型
查看AutoCompleteTextView的setAdapter()方法的源碼如下:
public <T extends ListAdapter & Filterable> void setAdapter(T adapter) {
if (mObserver == null) {
mObserver = new PopupDataSetObserver(this);
} else if (mAdapter != null) {
mAdapter.unregisterDataSetObserver(mObserver);
}
mAdapter = adapter;
if (mAdapter != null) {
//noinspection unchecked
mFilter = ((Filterable) mAdapter).getFilter();
adapter.registerDataSetObserver(mObserver);
} else {
mFilter = null;
}
mPopup.setAdapter(mAdapter);
}
自定義適配器核心代碼:
private PoiKeyTipListAdapter poiKeyTipListAdapter;
poiKeyTipListAdapter = new PoiKeyTipListAdapter(this);
nameEdit.setAdapter(poiKeyTipListAdapter);
nameEdit.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
if(nameEdit.getText().toString().length()>1){
//根據(jù)實(shí)際操作請(qǐng)求數(shù)據(jù)
}
}
@Override
public void afterTextChanged(Editable s) {
}
});
public class PoiKeyTipListAdapter extends BaseAdapter implements Filterable {
private List<SendNameBean.DataBean> stringArrayList ;
private Context context;
private OnDataChangedListener changedListener;
public PoiKeyTipListAdapter(Context context) {
this.context = context;
}
public void setData(List<SendNameBean.DataBean> stringArrayList){
this.stringArrayList = stringArrayList;
notifyDataSetChanged();
}
@Override
public int getCount() {
return stringArrayList == null ? 0 : stringArrayList.size();
}
@Override
public Object getItem(int position) {
return stringArrayList == null ? null : stringArrayList.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder;
if (convertView == null){
convertView = LayoutInflater.from(context).inflate(R.layout.item_input_tip_layout,parent,false);
viewHolder = new ViewHolder();
viewHolder.item_txt_tip = (TextView) convertView.findViewById(R.id.item_txt_tip);
viewHolder.name = (TextView) convertView.findViewById(R.id.name);
viewHolder.phone = (TextView) convertView.findViewById(R.id.phone);
convertView.setTag(viewHolder);
}else {
viewHolder = (ViewHolder) convertView.getTag();
}
viewHolder.item_txt_tip.setText(stringArrayList.get(position).getProvinceName()+stringArrayList.get(position).getCityName()+stringArrayList.get(position).getCountyName()+stringArrayList.get(position).getTownName()+stringArrayList.get(position).getAddress());
viewHolder.name.setText(stringArrayList.get(position).getName());
viewHolder.phone.setText(stringArrayList.get(position).getPhone());
convertView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (changedListener != null) {
changedListener.dataChangedListener(stringArrayList.get(position));
}
}
});
return convertView;
}
static class ViewHolder{
private TextView item_txt_tip ;
private TextView name ;
private TextView phone ;
}
@Override
public Filter getFilter() {
Filter filter=new Filter() {
@Override
protected FilterResults performFiltering(CharSequence constraint) {
FilterResults results = new FilterResults();
ArrayList<SendNameBean.DataBean> newData = new ArrayList<>();
if(stringArrayList!=null && stringArrayList.size()!=0){
newData.addAll(stringArrayList);
}
results.values = newData;
results.count = newData.size();
return results;
}
@Override
protected void publishResults(CharSequence constraint, FilterResults results) {
stringArrayList = (ArrayList)results.values;
notifyDataSetChanged();
}
};
return filter;
}
public interface OnDataChangedListener{
void dataChangedListener(SendNameBean.DataBean dataBean);
}
public void setOnDataChangedListener(OnDataChangedListener changedListener){
this.changedListener = changedListener;
}
}
效果圖

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
利用Android中的TextView實(shí)現(xiàn)逐字顯示動(dòng)畫
在安卓程序啟動(dòng)的時(shí)候,想逐字顯示一段話,每個(gè)字都有一個(gè)從透明到不透明的漸變動(dòng)畫。那如何顯示這個(gè)效果,下面一起來(lái)看看。2016-08-08
Android開(kāi)發(fā)中的ViewModel使用實(shí)戰(zhàn)案例
在Android應(yīng)用開(kāi)發(fā)中,ViewModel作為架構(gòu)組件,重要的功能是管理UI數(shù)據(jù)與生命周期,文章深入分析ViewModel如何感知View的生命周期,以及其核心優(yōu)勢(shì),包括生命周期感知、數(shù)據(jù)持久化和與UI層解耦,幫助開(kāi)發(fā)者利用ViewModel優(yōu)化應(yīng)用架構(gòu),需要的朋友可以參考下2024-10-10
Android開(kāi)發(fā)騰訊驗(yàn)證碼遇到的坑
這篇文章主要介紹了Android開(kāi)發(fā)騰訊驗(yàn)證碼遇到的坑,需要的朋友可以參考下2017-12-12
Android系統(tǒng)聯(lián)系人全特效實(shí)現(xiàn)(上)分組導(dǎo)航和擠壓動(dòng)畫(附源碼)
本文將為大家講解下Android系統(tǒng)聯(lián)系人全特效實(shí)現(xiàn)之分組導(dǎo)航和擠壓動(dòng)畫,具體實(shí)現(xiàn)及源代碼如下,感興趣的朋友可以參考下哈,希望對(duì)大家學(xué)習(xí)有所幫助2013-06-06
淺談android Fragment橫豎屏翻轉(zhuǎn)對(duì)重新加載的要求
下面小編就為大家分享一篇淺談android Fragment橫豎屏翻轉(zhuǎn)對(duì)重新加載的要求,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
Android 滑動(dòng)監(jiān)聽(tīng)的實(shí)例詳解
這篇文章主要介紹了Android 滑動(dòng)監(jiān)聽(tīng)的實(shí)例詳解的相關(guān)資料,希望通過(guò)本能幫助到大家,需要的朋友可以參考下2017-09-09
輕松實(shí)現(xiàn)功能強(qiáng)大的Android刮獎(jiǎng)效果控件(ScratchView)
這篇文章主要為大家詳細(xì)介紹了ScratchView如何一步步打造萬(wàn)能的Android刮獎(jiǎng)效果控件,,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
學(xué)習(xí)使用Material Design控件(三)使用CardView實(shí)現(xiàn)卡片效果
這篇文章主要為大家介紹了學(xué)習(xí)使用Material Design控件的詳細(xì)教程,如何使用CardView實(shí)現(xiàn)卡片效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07

