EditText监听,根据输入内容查询数据并动态更新ListView
Email:chentravelling@163.com
电话簿里有一个很实用的功能,就是根据姓名或者电话号码搜索联系人;很多网站或者软件有回复、评论、注册等功能,会限制输入字数,每当用户输入一个字数字后,会动态显示已经输入的字数或者剩余还能输入多少数字。在android系统里,我们可以通过对EditText进行监听,如果内容发生了改变就执行某项操作就行。
- 环境
> IDE:Android Studio
> JDK:1.8
> 系统:win7 64位
- 声明:
> 1)我查询数据和适配器是Cursor和SimpleCursorAdapter
> 2)关于ListView显示数据和动态更新可戳这里《[Cursor记录集游标、ListView和SimpleCursorAdapter、ListView数据动态更新](http://blog.csdn.net/chentravelling/article/details/50364162)》
- 步骤1:在Activity(继承ListActivity)中增加全局变量
~~~
private AddressDAO addressDAO;//操作数据库的类
private SimpleCursorAdapter adapter;//适配器
private Cursor cursor;//记录集游标
private EditText searchText;//搜索栏
private String condition;//查询条件
~~~
- 步骤2:在onCreate中为搜索栏添加监听事件
~~~
//需要先导入
import android.text.TextWatcher;
//然后添加监听事件
searchText = (EditText)findViewById(R.id.search);
searchText.addTextChangedListener(textWatcher);
~~~
- 步骤3:监听事件
~~~
TextWatcher textWatcher = new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
//Toast.makeText(ShowAddressActivity.this,"beforeTextChanged ",Toast.LENGTH_SHORT).show();
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
//Toast.makeText(ShowAddressActivity.this,"onTextChanged ",Toast.LENGTH_SHORT).show();
}
@Override
public void afterTextChanged(Editable s) {
//Toast.makeText(ShowAddressActivity.this,"afterTextChanged ",Toast.LENGTH_SHORT).show();
condition = searchText.getText().toString();
try{
cursor = addressDAO.conditionQuery(condition);
adapter.changeCursor(cursor);
}catch(Exception e){}
// new RefresListR().execute();
}
};
~~~
- 声明:adapter.changeCursor(Cursor)相当于通知适配器当前的数据集cursor已经改变了,需要刷新ListView了
- 步骤4:查询数据,才数据库操作类中增加查询函数
~~~
//查询数据:返回的是一个Cursor对象
public Cursor conditionQuery(String condition)
{
String sql;
if(condition.length()>0||!"".equals(condition))
{
sql = "select * from people where name like '%"+condition+"%' or phone like '%"+condition+"%'";
}else
{
sql = "select * from people";
}
//获取SQLiteDatabase对象实例
db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(sql, null);
return cursor;
}
~~~
通过上面4个步骤,基本可以完成在搜索栏根据输入的文字进行条件查询,亲测了一下。当然可能数据过多的时候,采用这个方法可能会造成读取时间长的问题,那么最好可以使用后台线程读取数据库,可参考《[Cursor记录集游标、ListView和SimpleCursorAdapter、ListView数据动态更新](http://blog.csdn.net/chentravelling/article/details/50364162)》。
初学者个人理解,难免有误,欢迎指正。