热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

edittext+listview实现搜索listview中的内容方法(推荐)

下面小编就为大家带来一篇edittext+listview实现搜索listview中的内容方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

主要原理:是在主界面有两个空间,一个是EditText,一个是ListView,ListView是放在EditText下面的,然后自定义建立一个adapter适配器,

这个适配器要继承Filterable这个接口,并实现这个接口的两个方法,一个是过滤方法,一个是过滤后的方法,一般我们是在过滤方法里面实现过滤,

在过滤后的方法里面调用notifyDataSetChanged();也就是使适配器更新数据,这里还有用到一个pinyin4j-2.5.0.jar的架包,这个主要是汉字转拼

音的功能

MainActivity.Java

public class MainActivity extends Activity { 
 private EditText et_filter; 
 private UserAdapter adapter; 
 private ListView lv_list; 
 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.activity_main); 
  List userInfos = new ArrayList(); 
  for (int i = 0; i <2; i++) { 
   UserInfo user = new UserInfo(); 
   user.setUsername("张三" + i); 
   user.setPhonenum("12345" + i); 
   userInfos.add(user); 
  } 
  for (int i = 0; i <2; i++) { 
   UserInfo user = new UserInfo(); 
   user.setUsername("李四" + i); 
   user.setPhonenum("12345" + i); 
   userInfos.add(user); 
  } 
   
  lv_list = (ListView) findViewById(R.id.lv_list); 
  adapter = new UserAdapter(MainActivity.this, userInfos); 
  lv_list.setAdapter(adapter); 
   
  et_filter = (EditText) findViewById(R.id.et_filter); 
  et_filter.addTextChangedListener(new TextWatcher() { 
 
   @Override 
   public void onTextChanged(CharSequence s, int start, int before, 
     int count) { 
    adapter.getFilter().filter(et_filter.getText().toString()); 
 
   } 
 
   @Override 
   public void beforeTextChanged(CharSequence s, int start, int count, 
     int after) { 
     
   } 
 
   @Override 
   public void afterTextChanged(Editable s) { 
 
   } 
  }); 
 
 } 
} 

UserAdapter.java

package com.example.edittextfilterdemo; 
import java.util.ArrayList; 
import java.util.List; 
import android.content.Context; 
import android.util.Log; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 
import android.widget.Filter; 
import android.widget.Filterable; 
import android.widget.TextView; 
/** 
 * 自定义具有过滤功能的adapter类 
 * 
 */ 
public class UserAdapter extends BaseAdapter implements Filterable { 
 private MyFilter myFilter; 
 private List userInfos; 
 private Context context; 
 private ArrayList mOriginalValues; 
 
  private final Object mLock = new Object(); 
 
  public UserAdapter(Context context, List userInfos) { 
   this.cOntext= context; 
   this.userInfos = userInfos; 
 
  } 
 
  @Override 
  public int getCount() { 
   // TODO Auto-generated method stub 
   return userInfos.size(); 
  } 
 
  @Override 
  public Object getItem(int arg0) { 
   // TODO Auto-generated method stub 
   return userInfos.get(arg0); 
  } 
 
  @Override 
  public long getItemId(int position) { 
   // TODO Auto-generated method stub 
   return position; 
  } 
 
  @Override 
  public View getView(int position, View convertView, ViewGroup parent) { 
 
   View view = convertView; 
 
   ViewHolder holder; 
   if (view == null) { 
    view = LayoutInflater.from(context).inflate(R.layout.list_item, 
     null); 
    holder = new ViewHolder(); 
 
    holder.tv_nick = (TextView) view.findViewById(R.id.tv_nick); 
    holder.tv_mobile = (TextView) view.findViewById(R.id.tv_mobile); 
    view.setTag(holder); 
   } else { 
    holder = (ViewHolder) view.getTag(); 
   } 
 
   holder.tv_nick.setText(userInfos.get(position).getUsername()); 
   holder.tv_mobile.setText(userInfos.get(position).getPhonenum()); 
 
   return view; 
  } 
 
  static class ViewHolder { 
 
   TextView tv_nick; 
   TextView tv_mobile; 
  } 
 
  @Override 
  public Filter getFilter() { 
   if (myFilter == null) { 
    myFilter = new MyFilter(); 
   } 
   return myFilter; 
  } 
 
  class MyFilter extends Filter { 
 
   @Override 
   protected FilterResults performFiltering(CharSequence prefix) { 
    // 持有过滤操作完成之后的数据。该数据包括过滤操作之后的数据的值以及数量。 count:数量 values包含过滤操作之后的数据的值 
    FilterResults results = new FilterResults(); 
 
    if (mOriginalValues == null) { 
    synchronized (mLock) { 
     // 将list的用户 集合转换给这个原始数据的ArrayList 
     mOriginalValues = new ArrayList(userInfos); 
    } 
    } 
    if (prefix == null || prefix.length() == 0) { 
    synchronized (mLock) { 
     ArrayList list = new ArrayList( 
       mOriginalValues); 
     results.values = list; 
     results.count = list.size(); 
    } 
    } else { 
    // 做正式的筛选 
    String prefixString = prefix.toString().toLowerCase(); 
 
    // 声明一个临时的集合对象 将原始数据赋给这个临时变量 
    final ArrayList values = mOriginalValues; 
 
    final int count = values.size(); 
 
    // 新的集合对象 
    final ArrayList newValues = new ArrayList( 
      count); 
 
    for (int i = 0; i ) results.values; 
 
    if (results.count > 0) { 
    notifyDataSetChanged(); 
    } else { 
    notifyDataSetInvalidated(); 
    } 
   } 
 
  } 
 } 

activity_main.xml:

 
 
  
 
  
  
 
 

以上这篇edittext + listview 实现搜索listview中的内容方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


推荐阅读
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 本文探讨了 RESTful API 和传统接口之间的关键差异,解释了为什么 RESTful API 在设计和实现上具有独特的优势。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 本文介绍如何在 Unity 的 XML 配置文件中,将参数传递给自定义生命周期管理器的构造函数。我们将详细探讨 CustomLifetimeManager 类的实现及其配置方法。 ... [详细]
  • 本文详细介绍了 Java 中 org.apache.xmlbeans.SchemaType 类的 getBaseEnumType() 方法,提供了多个代码示例,并解释了其在不同场景下的使用方法。 ... [详细]
  • 本文详细介绍了如何解决MyBatis中常见的BindingException错误,提供了多种排查和修复方法,确保Mapper接口与XML文件的正确配置。 ... [详细]
author-avatar
汤侑亦_473
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有