}
//查询联系人
public void queryContacts(View view){ Cursor cursor=null; /** * 通过Context的getContentResolver(),得到一个ContentResolver对象,从而进行CRUD操作, * 和SQLiteOpenHelper的CRUD方法一样,不同的是,在ContentReslover进行CRUD操作时,不接受表名, * 而是接受一个Uri类型的对象作为参数,这个参数称为内容URI; * 内容URI的组成:协议://权限/路径;协议是content,权限一般是包名,如com.example,路径是对不同的表作 * 区分,如存在两张表table1和table2,则完整的内容URI可以写成:content://com.example.person/table1, * 然后,把内容URI解析成Uri对象:Uri.Parse(String URI); * */ cursor=getContentResolver().query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, null, null, null); while(cursor.moveToNext()){ String body=cursor.getString(cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME)); String address=cursor.getString(cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER)); data.add(body+"\n"+address); } //更新适配器 adapter.notifyDataSetChanged(); }}
三。运行效果: