Android 依据EditText搜索框ListView动态显示数据
依据EditText搜索框ListView动态显示数据是依据需求来的,认为这之中涉及的东西可能比較的有意思,所以动手来写一写。希望对大家有点帮助。
首先。我们来分析下整个过程:
1、建立一个layout,包括一个EditText搜索框和一个ListView
2、创建一个数据集mData,用于ListView的Adapter的创建
3、加入EditText的文本改变的监听器
4、利用notifyDataSetChanged()动态更新ListView
第一步:创建一个搜索框
这个还是比較easy的。这里我使用的是http://blog.csdn.net/walker02/article/details/7917392该文章的文本框。具有点叉全删功能,只是,删除了搜索button,由于我们动态搜索,用不到button。
加入一个Relativelayout布局,然后往里加入两个控件(详细是3个),
效果如上,xml代码例如以下:
<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="match_parent"
tools:context="com.ricawinter.dynamicsearch.MainActivity$PlaceholderFragment" > <RelativeLayout android:id="@+id/top"
android:layout_width="fill_parent"
android:layout_alignParentTop="true"
android:paddingLeft="10dp"
android:paddingRight="10dp"
android:background="@drawable/top_background"
android:layout_height="wrap_content"> <RelativeLayout
android:id="@+id/rlSearchFrameDelete"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:gravity="center_vertical" > <EditText android:id="@+id/etSearch"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:singleLine="true"
android:background="@drawable/search_frame"
android:layout_marginRight="10dp"
android:paddingLeft="32dp"
android:textSize="12sp"
android:hint="Searching..."/> <ImageView android:id="@+id/ivDeleteText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:src="@drawable/delete"
android:layout_centerInParent="true"
android:paddingRight="20dp"
android:visibility="gone"/> </RelativeLayout> </RelativeLayout> <ListView
android:id="@+id/mListView"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/top" >
</ListView> </RelativeLayout>
第二步:创建数据集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.\n2014.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.\n2014.09.18.16.33");
item = new HashMap<String, Object>();
item.put("title", mListTitle.get(1));
item.put("text", mListText.get(1));
mDatas.add(item);
}
再就是利用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函数參数是传递引用进来的原因。假设直接返回一个引用回去。那么就会出现这个问题,因此这一点须要注意下。
能够參考http://www.2cto.com/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);
}
}
}
4、由于文本框在第一个,所以程序一执行。文本框就会获得焦点,然后弹出输入法,这里使用在xml文件中加入一个长宽为0的LinearLayout来获得焦点,代码例如以下:
<!-- to acquire focus -->
<LinearLayout
android:focusable="true"
android:focusableInTouchMode="true"
android:layout_width="0px"
android:layout_height="0px"/>
综上。这个动态的方法。可能还须要待改进,比方筛选的方法,并且控件这里仅仅是针对SampleAdapter的Listview,假设是自己定义的ListView。应该是还能够再进行优化的。还有就是ListView的height的设置,设置成wrap_content和fill_parent两种方法事实上换成真机是能够体验出两种的差距的。比較明显吧。就是往下划的过程。
写的比較简单粗暴,不要太见怪。附上代码一份》
向来喜欢共享, 所以免费下载。
Android 依据EditText搜索框ListView动态显示数据的更多相关文章
- Android 根据EditText搜索框ListView动态显示数据
根据EditText搜索框ListView动态显示数据是根据需求来的,觉得这之中涉及的东西可能比较的有意思,所以动手来写一写,希望对大家有点帮助. 首先,我们来分析下整个过程: 1.建立一个layou ...
- 详细解读Android中的搜索框(二)—— Search Dialog
Search Dialog是提供搜索的控件之一,还有一个是上次小例子给出的searchView,关于SearchView的东西后面会说到.本次先从Search Dialog说起,让大家慢慢理解andr ...
- 详细解读Android中的搜索框—— SearchView
以前总是自己写的 今天看看别人做的 本篇讲的是如何用searchView实现搜索框,其实原理和之前的没啥差别,也算是个复习吧. 一.Manifest.xml 这里我用一个activity进行信息的输入 ...
- 详细解读Android中的搜索框(三)—— SearchView
本篇讲的是如何用searchView实现搜索框,其实原理和之前的没啥差别,也算是个复习吧. 一.Manifest.xml 这里我用一个activity进行信息的输入和展示,配置方式还是老样子,写一个输 ...
- 详细解读Android中的搜索框(一)—— 简单小例子
这次开的是一个讲解SearchView的栏目,第一篇主要是给一个小例子,让大家对这个搜索视图有一个了解,之后再分布细化来说. 目标: 我们先来定个目标,我们通过搜索框来输入要搜索的联系人名字,输入的时 ...
- android开发中难免遇到listview刷新数据出现异常
异常:java.lang.IllegalStateException: The content of the adapter has changed but ListView did not rece ...
- 详细解读Android中的搜索框(四)—— Searchable配置文件
<?xml version="1.0" encoding="utf-8"?> <searchable xmlns:android=" ...
- C#用HttpClient抓取jd.com搜索框下拉数据
添加System.Web.dll引用 添加System.Net.Http引用 using System.Net.Http; using System.Web; string key = "电 ...
- android浮动搜索框
android浮动搜索框的配置比较繁琐,需要配置好xml文件才能实现onSearchRequest()方法. 1.配置搜索的XML配置文件,新建文件searchable.xml,保存在res/xml ...
随机推荐
- 【转】mysql的数据类型
转自:http://mrxiong.blog.51cto.com/287318/1651098 一.数值类型 Mysql支持所有标准SQL中的数值类型,其中包括严格数据类型(INTEGER,SMALL ...
- javascript特殊值常量
Infinity 表示无穷大的特殊值.当数字运算结果超出javascript能表示的数字范围时. Nan 特殊的非数字值(not a number).0除0.数字运算符的操作数为字符等情况. Numb ...
- JVM 内存分配和垃圾回收(GC)机制
一 判断对象是否存活 垃圾收集器在对堆进行回收前,第一件事情就是要确定这些对象之中哪些还“活着”,哪些已经"死去”,即不能再被任何途径使用的对象. 1.1 引用计数法 (Reference ...
- [转]python模块全面
python模块 http://www.cnblogs.com/wupeiqi/articles/4963027.html 模块概念:用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编 ...
- SQL查询性能优化
使用高效的查询 使用 EXISTS 代替 IN -- 查询A表中同时存在B表的数据 -- 慢 SELECT * FROM Class_A WHERE id IN (SELECT id FROM Cla ...
- python dns请求
一.DNS dns(domain name system)域名系统 ,主要用来把主机名转换成ip地址.其至今能存在的原因有两个: 能使人们记住名字,而不是ip地址: 允许服务器改变地址,但使用相同的名 ...
- Java数值数学类
Java数值数学类 序号 方法与描述 1 xxxValue() 将 Number 对象转换为xxx数据类型的值并返回. 2 compareTo() 将number对象与参数比较. 3 equals ...
- sql的四种连接方式
1.内联接.(典型的联接运算,使用像 = 或 <> 之类的比较运算符).包括相等联接和自然联接. 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行.例如,检索 students ...
- modelsim 仿真软件 百度云分享 modelsim se 10.7 10.6d 10.6c 10.5 10.4
modelsim se 10.7 链接:https://pan.baidu.com/s/1NDC2yMCZmA4bIRSk2dUiTg 提取码:4l1d 复制这段内容后打开百度网盘手机App,操作更方 ...
- uva 227 Puzzle (UVA - 227)
感慨 这个题实在是一个大水题(虽然说是世界决赛真题),但是它给出的输入输出数据,标示着老子世界决赛真题虽然题目很水但是数据就能卡死你...一直pe pe直到今天上午AC...无比感慨...就是因为最后 ...