Android自定义输入框提示功能

本文实例为大家分享了Android自定义输入框提示的具体代码,供大家参考,具体内容如下

这是系统提供的一个控件: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="请输入姓名"/>

但是我们想在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){
     //根据实际操作请求数据

    }
   }

   @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;
 }

}

效果图

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android开发之WebView输入框提示解决办法

    做基于WebView应用时,页面上有一个输入框,当输入的文字过多时,超过输入框的行数时,输入框能够滚动,这时间问题来了,输入的提示箭头会移动到输入框外,如何解决这个问题呢,查找chromium源码如下: void LoadIfNecessary(jobject context) { if (loaded_) return; loaded_ = true; TRACE_EVENT0("browser", "HandleResources::Create"); JNIE

  • Android编程实现输入框动态自动提示功能

    本文实例讲述了Android编程实现输入框动态自动提示功能.分享给大家供大家参考,具体如下: 关于AutoCompleteTextView的使用,我想大家并不陌生,对其设定上Adapter后系统便能自己识别与匹配了.近期 一个项目中,需要做到匹配通迅录中的电话号码和联系人,由于通迅录中数据量大,所以把所有的数据在自己提示之前就查询出来并加入到 AutoCompleteTextView中是不现实的,所以我们可以使用cursor来动态加载AutoCompleteTextView的数据,从而 实现时时

  • Android自定义输入框提示功能

    本文实例为大家分享了Android自定义输入框提示的具体代码,供大家参考,具体内容如下 这是系统提供的一个控件:AutoCompleteTextView <AutoCompleteTextView android:layout_marginLeft="20dp" android:id="@+id/name_edit" android:layout_width="wrap_content" android:layout_height=&quo

  • Android自定义弹窗提示效果

    本文实例为大家分享了Android 自定义弹窗提示的具体代码,供大家参考,具体内容如下 Java文件: private void showSetDeBugDialog() { AlertDialog.Builder setDeBugDialog = new AlertDialog.Builder(this); //获取界面 View dialogView = LayoutInflater.from(this).inflate(R.layout.system_admin_psw_alert_dia

  • Android自定义录制视频功能

    Android录制视频MediaRecorder+SurfaceView的使用方法,供大家参考,具体内容如下 先看效果图: <1>将视频动画显示到SurfaceView控件上 <2>使用MediaRecorder类进行视频的录制 常用的方法: mediaRecorder.reset(); mediaRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA); //从照相机采集视频 mediaRecorder.setAudioS

  • Android自定义View实现搜索框(SearchView)功能

    概述 在Android开发中,当系统数据项比较多时,常常会在app添加搜索功能,方便用户能快速获得需要的数据.搜索栏对于我们并不陌生,在许多app都能见到它,比如豌豆荚 在某些情况下,我们希望我们的自动补全信息可以不只是纯文本,还可以像豌豆荚这样,能显示相应的图片和其他数据信息,因此Android给我们提供的AutoCompleteTextView往往就不够用,在大多情况下我们都需要自己去实现搜索框. 分析 根据上面这张图,简单分析一下自定义搜索框的结构与功能,有 1. 搜索界面大致由三部门组成

  • js输入框邮箱自动提示功能代码实现

    同理 此插件不需要任何html标签,只需要一个输入框 有相对应的class类名就ok 且父级有个class类名,其他的都不需要.内部的HTML代码都是自动生成的. HTML代码如下: 复制代码 代码如下: <div class="parentCls">    <input type="text" class="inputElem"> </div> 其实上面的div标签都可以不需要 只需要在input输入框 且父

  • Android自动文本框输入识别提示功能代码

    自动提示文本框(AutoCompleteTextView)可以加强用户体验,缩短用户的输入时间(百度的搜索框就是这个效果). 相信大家都熟悉自动识别提示吧,在我们的生活中随处可见,今天就让我为大家简单介绍一下它是如何设计的. 所谓自动识别输入即是根据用户输入的已有信息,为用户提示可能的值,方便用户完成输入.在Android设备上这种功能分为:AutoCompleteTextView和MultiAutoCompleteTextView,前者为单个的自动识别,类似与搜索引擎的输入框提示:后者为多个值

  • Android实现自定义带删除功能的EditText实例

    1.说明 自定义带删除功能的EditText有两种方法,第一种是用组合视图的方法,即在一个view视图里面左侧放置一个EditText,右侧放置一个ImageView,但是这样增加了视图的层次,而且对输入内容的长度要做一定的处理. 第二种是重新定义EditText组件,增加相应的事件处理,即可达到很好的效果,效果图如下: 2.ClearEditText的JAVA类文件 /** * @说明: 自定义带删除按钮的EditText * */ public class ClearEditText ext

  • Android自定义带增长动画和点击弹窗提示效果的柱状图DEMO

    项目中最近用到各种图表,本来打算用第三方的,例如MPAndroid,这是一个十分强大的图表库,应用起来十分方便,但是最终发现和设计不太一样,没办法,只能自己写了.今天将写好的柱状图的demo贴在这,该柱状图可根据数据的功能有一下几点: 1. 根据数据的多少,动态的绘制柱状图柱子的条数: 2. 柱状图每条柱子的绘制都有动态的动画效果: 3. 每条柱子有点击事件,点击时弹出提示框,显示相关信息,规定时间后,弹窗自动消失. 好了,先上演示图: 下边贴出相关代码: 自定义柱状图类: package co

  • Android自定义View之绘制圆形头像功能

    前言 做APP应用开发的时候,用户头像肯定是必不可少的,但是90%以上的需求头像都是圆形的.那么,如何通过自定义View的方式实现圆形头像呢,那么,本片博文会告诉你不仅仅是实现过程.一定会有意想不到的收获哦! 最终效果 国际惯例,我们先来看最终实现的效果图 自定义RoundImageView继承自ImageView public class RoundImageView extends ImageView { public RoundImageView(Context context) { su

随机推荐