Android中CursorJoiner的使用

public class CursorJoinerActivity extends Activity {

ListView listView;

ContentResolver contentResolver;

 

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.listview_layout);

contentResolver = getContentResolver();

listView = (ListView) findViewById(R.id.listFav);

operateContentResolver();

// listView.setAdapter(adapter);

 

}

 

// 操作ContentResolver

public void operateContentResolver() {

StringBuilder sb = new StringBuilder();

// 1) prepare cursors

Cursor contactsCursor = contentResolver.query(

ContactsContract.Contacts.CONTENT_URI, new String[] {

ContactsContract.Contacts._ID,

ContactsContract.Contacts.DISPLAY_NAME, }, null, null,

ContactsContract.Contacts._ID);

 

Cursor phoneCursor = contentResolver.query(

ContactsContract.CommonDataKinds.Phone.CONTENT_URI,

new String[] { ContactsContract.CommonDataKinds.Phone._ID,

ContactsContract.CommonDataKinds.Phone.CONTACT_ID,

ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME,

ContactsContract.CommonDataKinds.Phone.NUMBER }, null,

null, ContactsContract.CommonDataKinds.Phone.CONTACT_ID);

CursorJoiner joiner = new CursorJoiner(

contactsCursor,

new String[] { ContactsContract.Contacts._ID },

phoneCursor,

new String[] { ContactsContract.CommonDataKinds.Phone.CONTACT_ID });

MatrixCursor cursor = new MatrixCursor(new String[] {"_id",  "display_name",

"phoneNumber" }, 10);

for (CursorJoiner.Result joinerResult : joiner) {

switch (joinerResult) {

case BOTH: // handle case where a row

String id = phoneCursor.getString(phoneCursor

.getColumnIndex("contact_id"));

String name = contactsCursor.getString(contactsCursor

.getColumnIndex("display_name"));

String phoneNumber = phoneCursor.getString(phoneCursor

.getColumnIndex("data1"));

cursor.addRow(new String[] {id,  name, phoneNumber });

break;

}

}

//使用simpleCursorAdapter 装载数据

try {

startManagingCursor(cursor);

SimpleCursorAdapter listAdapter = new SimpleCursorAdapter(this,

R.layout.contact, cursor, new String[] { "_id",

"display_name", "phoneNumber" }, new int[] {R.id.contactId,

R.id.displayName, R.id.phoneNumber });

listView.setAdapter(listAdapter);

} catch (Exception e) {

e.printStackTrace();

}

}

 

}

通过联系人中的contacts表和phone表,获得一个联系人对应的电话号码

效果图如下:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值