Android 根据EditText搜索框ListView动态显示数据

根据EditText搜索框ListView动态显示数据是根据需求来的,觉得这之中涉及的东西可能比较的有意思,所以动手来写一写,希望对大家有点帮助。

首先,我们来分析下整个过程:

1、建立一个layout,包含一个EditText搜索框和一个ListView

2、创建一个数据集mData,用于ListView的Adapter的创建

3、添加EditText的文本改变的监听器

4、利用notifyDataSetChanged()动态更新ListView

第一步:创建一个搜索框

这个还是比较容易的,这里我使用的是http://blog.csdn.net/walker02/article/details/7917392该文章的文本框,具有点叉全删功能,不过,删除了搜索按钮,因为我们动态搜索,用不到按钮。

添加一个Relativelayout布局,然后往里添加两个控件(具体是3个),

效果如上,xml代码如下:

第二步:创建数据集mData

这里使用的是SimpleAdapter,所以数据集创建的格式我的是这样的,自己根据自己的Adapter来建立元数据,存放在mListTitle和mListText里的数据是不会去改的,而mData是会在文本框改变时,mData的数据也会做相应的改变,这个是更新操作需要做的。这里是创建元数据集,

代码如下:

  ListView mListView;

  ArrayList<map<string, object="">> mData = new ArrayList<map<string, object="">>();

  ArrayList<string> mListTitle = new ArrayList<string>();
  ArrayList<string> mListText = new ArrayList<string>();

  private void getmData(ArrayList<map<string, object="">> mDatas)
  {
    Map<string, object=""> item = new HashMap<string, object="">();
    mListTitle.add(This is a title!);
    mListText.add(this is a text.
2014.09.18.16.33);

    item.put(title, mListTitle.get(0));
    item.put(text, mListText.get(0));
    mDatas.add(item);
    mListTitle.add(This is an another title!);
    mListText.add(this is an another text.
2014.09.18.16.33);

    item = new HashMap<string, object="">();
    item.put(title, mListTitle.get(1));
    item.put(text, mListText.get(1));
    mDatas.add(item);
  }</string,></string,></string,></map<string,></string></string></string></string></map<string,></map<string,>

再就是利用mData创建Adapter

private void set_mListView_adapter()
{
 mListView = (ListView) findViewById(R.id.mListView);

 getmData(mData);

 adapter = new SimpleAdapter(this,mData,android.R.layout.simple_list_item_2,
   new String[]{title,text},new int[]{android.R.id.text1,android.R.id.text2});

 mListView.setAdapter(adapter);
}

到此,程序开始的状态是显示出来了的。如果没有搜索框,到此就可以了。

第三步:添加EditText的文本改变的监听器

因为我们要动态修改ListView的显示,所以就必须去监听,然后做相应的动作。当监听到文本改变时,就用Handler post一个Runnable去做相应的改变。

private void set_eSearch_TextChanged()
{
 eSearch = (EditText) findViewById(R.id.etSearch);

 eSearch.addTextChangedListener(new TextWatcher() {

   @Override
   public void onTextChanged(CharSequence arg0, int arg1, int arg2, int arg3) {
    // TODO Auto-generated method stub
    //这个应该是在改变的时候会做的动作吧,具体还没用到过。
   }

   @Override
   public void beforeTextChanged(CharSequence arg0, int arg1, int arg2,
      int arg3) {
    // TODO Auto-generated method stub
    //这是文本框改变之前会执行的动作
   }

   @Override
   public void afterTextChanged(Editable s) {
    // TODO Auto-generated method stub
    /**这是文本框改变之后 会执行的动作
     * 因为我们要做的就是,在文本框改变的同时,我们的listview的数据也进行相应的变动,并且如一的显示在界面上。
     * 所以这里我们就需要加上数据的修改的动作了。
     */
    if(s.length() == 0){
      ivDeleteText.setVisibility(View.GONE);//当文本框为空时,则叉叉消失
    }
    else {
      ivDeleteText.setVisibility(View.VISIBLE);//当文本框不为空时,出现叉叉
      myhandler.post(eChanged);
    }
   }
 });

}

Handler在此体现了巨大的用途,我们可以根据Handler的这样的一个post功能,可以对界面神马的做自己想要的改变,可以不仅仅只是ListView的修改,像每输入个字,字体就改变成另一种颜色什么的,都可以。

第四步:利用notifyDataSetChanged()动态更新ListView

回归正题,这里是最关键得一步,我们post出来了,那么我们就要根据搜索文本框的文本然后对元数据进行筛选,再让符合的数据显示在ListView上。

(/*丫的,顶着S4在写博客,是不是一种罪过...*/)

adapter有一个notifyDataSetChanged()的方法,在数据更新的时候就使用此方法即可更新绑定的ListView,效果如下:

输入一个5还是是有两个item的,我的选择是,只要title和text包含文本框的字符,即是目标item

当输入50时,因为只有一个item里的title或text的文本里包含了搜索框的文本,所以只显示只包含的这一个

再加上一个0,因为没有item的文本包含500,所以Listview没有item了

顺利完成效果的,真棒,LZ水平太菜,遇到了些许问题。

这里可能会遇到一些问题:

1、notifyDataSetChanged(),这个更新了,mData数据集也确实改变了,但是ListView却没有更新。我之前就是这样,后来发现时mData数据集的引用改变了,所以Adapter再notify也没用,因为Adapter是和mData的引用绑定的,引用一变,那么数据是不会更新到ListView上的。这也是我使用get函数参数是传递引用进来的原因,如果直接返回一个引用回去,那么就会出现这个问题,因此这一点需要注意下。可以参考/kf/201401/273017.html

2、关于界面UI的更新,可以使用Handler,通过Post一个Runnable去更新,Runnable会去根据搜索框的文本对mData里的数据进行更新。

代码如下:

Runnable eChanged = new Runnable() {

 @Override
 public void run() {
   // TODO Auto-generated method stub
   String data = eSearch.getText().toString();

   mData.clear();

   getmDataSub(mData, data);

   adapter.notifyDataSetChanged();

 }
};

3、可能对mData的理解会有点问题,因为数据更新完后,每一次的筛选数据都是放在mData里,那么原本的数据呢,当然就是在mListTitle和mListText里。根据获得数据的getmDataSub的代码即可知。

private void getmDataSub(ArrayList<map<string, object="">> mDataSubs, String data)
{
  int length = mListTitle.size();
  for(int i = 0; i < length; ++i){
   if(mListTitle.get(i).contains(data) || mListText.get(i).contains(data)){
    Map<string,object> item = new HashMap<string,object>();
    item.put(title, mListTitle.get(i));
    item.put(text, mListText.get(i));
    mDataSubs.add(item);
   }
  }
} </string,object></string,object></map<string,>

4、因为文本框在第一个,所以程序一运行,文本框就会获得焦点,然后弹出输入法,这里使用在xml文件里添加一个长宽为0的LinearLayout来获得焦点,代码如下:

综上,这个动态的方法,可能还需要待改进,比如筛选的方法,而且控件这里只是针对SampleAdapter的Listview,如果是自定义的ListView,应该是还可以再进行优化的。还有就是ListView的height的设置,设置成wrap_content和fill_parent两种方法其实换成真机是可以体验出两种的差距的,比较明显吧,就是往下划的过程。

以上就是Android 根据EditText搜索框ListView动态显示数据的实例,希望能帮助有需要的朋友,谢谢大家对本站的支持!

(0)

相关推荐

  • Android搜索框组件SearchView的基本使用方法

    SearchView是android系统中内置的一个搜索框组件,可以很方便在添加在用户界面之上,但是也带来了一些问题,那就是searchview的UI是固定的,定制起来会很麻烦,如果对SearchView的要求比较高,完全可以采用button和EditText自己实现.这里先简单的说说SearchView的使用: main.xml: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" x

  • Android搜索框(SearchView)的功能和用法详解

    SearchView是搜索框组件,它可以让用户在文本框里输入文字,通过监听器取得用户的输入,当用户点击搜索时,监听器执行实际的搜索. 1.SearchView组件的常用方法如下: ①setIconifiedByDefault(boolean iconified) ===> 设置搜索框默认是否自动缩小为图标. ②setOnQueryTextListener(SearchView,OnQueryTextListener listener) ===> 为搜索框设置监听器 ③setSubmitButt

  • Android搜索框通用版

    之前项目总会遇到很多搜索框类的功能,虽然不是很复杂,不过每次都要去自己处理数据,并且去处理搜索框的变化,写起来也比较麻烦,今天来做一个比较简单的通用搜索栏. 先看下效果图: 没什么特别的,只是今天要做的就是简单的把搜索框的内容封装一下. 一.分析功能 先考虑一下,搜索框一般都是由一个搜索图标(一般都是一个放大镜),一个输入框和一个清除按钮组成.然后会通过监听输入框的变化去处理清除按钮的显示和隐藏并且去过滤相关的数据.最后去刷新适配器,显示过滤后的数据.基本上搜索框的功能都大同小异. 有了上边的分

  • Android SearchView搜索框组件的使用方法

    SearchView是搜索框组件,它可以让用户在文本框里输入文字,通过监听器取得用户的输入,当用户点击搜索时,监听器执行实际的搜索. 本文就为大家分享了SearchView搜索框组件的使用方法,供大家参考,具体内容如下 效果: 代码SearchActivity.java package com.jialianjia.bzw.activity; import android.os.Bundle; import android.widget.ArrayAdapter; import android.

  • Android实现简单实用的搜索框

    本文实例为大家分享了Android实现搜索框展示的具体代码,供大家参考,具体内容如下 展示效果 代码区 SouActivity public class SouActivity extends AppCompatActivity implements TextWatcher{ @BindView(R.id.app_sou) EditText appSou; @BindView(R.id.app_sou_list) ListView appSouList; @BindView(R.id.activ

  • Android EditText搜索框实现图标居中

    类似这样EditText 搜索框,hiht 提示有一个icon并且text内容. 重写EditText : package mobi.truekey.weapp2.widget; import android.content.Context; import android.content.res.TypedArray; import android.graphics.Canvas; import android.graphics.Paint; import android.graphics.dr

  • android搜索框上下滑动变色效果

    搜索框上下滑动变透明度是现在APP中很常见的效果,先看看效果: 首先来看下布局骨架: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height

  • Android搜索框SearchView属性和用法详解

    SearchView简介 SearchView是Android原生的搜索框控件,它提供了一个用户界面,用于用户搜索查询. SearchView默认是展示一个search的icon,点击icon展开搜索框,如果你想让搜索框默认就展开,可以通过setIconifiedByDefault(false);实现. SearchView属性 SearchView使用 xml中定义SearchView: <?xml version="1.0" encoding="utf-8"

  • Android的搜索框架实例详解

    基础知识 Android的搜索框架将代您管理的搜索对话框,您不需要自己去开发一个搜索框,不需要担心要把搜索框放什么位置,也不需要担心搜索框影响您当前的界面.所有的这些工作都由SearchManager类来为您处理(以下简称"搜索管理器"),它管理的Android搜索对话框的整个生命周期,并执行您的应用程序将发送的搜索请求,返回相应的搜索关键字. 当用户执行一个搜索,搜索管理器将使用一个专门的Intent把搜索查询的关键字传给您在配置文件中配置的处理搜索结果的Activity.从本质上讲

  • Android中如何实现清空搜索框的文字

    需求:项目中的有关搜索的地方,加上清空文字的功能,目的是为了增加用户体验,使用户删除文本更加快捷 解决过程:开始的时候感觉这个东西不太好实现,主要就是布局的问题,可能是开始顾虑的太多了,再加上当时产品催的不太紧,而且这个功能也不是必须实现的.但是今天不一样了,这个是老大让加上的,说别的很多应用中都有这个功能,没办法那就加上呗,试着去使用了相对布局去实现,把一个删除按键放在编辑框的右上方,当文字的时候就把删除按键给显示出来,当编辑框为空的时候就把删除按键给隐藏掉.布局代码 <?xml versio

随机推荐