EditText监听,根据输入内容查询数据并动态更新ListView

最后更新于:2022-04-01 19:58:10

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)》。 初学者个人理解,难免有误,欢迎指正。
';