`

android中联系人 以及 ContactsContract类

 
阅读更多

1.加入读写权限

  1. <uses-permission android:name="android.permission.READ_CONTACTS" />
  2. <uses-permission android:name="android.permission.WRITE_CONTACTS" />

联系人信息Uri:

content://com.android.contacts/contacts

联系人电话Uri:

content://com.android.contacts/data/phones

联系人Email Uri:

content://com.android.contacts/data/emails


(推荐)也可以这样获取联系人信息Uri:Uri uri = ContactsContract.Contacts.CONTENT_URI;



2.查询与添加联系人的操作(单元测试用例)


  1. public class ContactTest extends AndroidTestCase
  2. {
  3. private static final String TAG = "ContactTest";
  4. public void testGetAllContact() throws Throwable
  5. {
  6. //获取联系人信息的Uri
  7. Uri uri = ContactsContract.Contacts.CONTENT_URI;
  8. //获取ContentResolver
  9. ContentResolver contentResolver = this.getContext().getContentResolver();
  10. //查询数据,返回Cursor
  11. Cursor cursor = contentResolver.query(uri, null, null, null, null);
  12. while(cursor.moveToNext())
  13. {
  14. StringBuilder sb = new StringBuilder();
  15. //获取联系人的ID
  16. String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
  17. //获取联系人的姓名
  18. String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
  19. //构造联系人信息
  20. sb.append("contactId=").append(contactId).append(",Name=").append(name);
  21. //查询电话类型的数据操作
  22. Cursor phones = contentResolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
  23. null,
  24. ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = "+ contactId,
  25. null, null);
  26. while(phones.moveToNext())
  27. {
  28. String phoneNumber = phones.getString(phones.getColumnIndex(
  29. ContactsContract.CommonDataKinds.Phone.NUMBER));
  30. //添加Phone的信息
  31. sb.append(",Phone=").append(phoneNumber);
  32. }
  33. phones.close();
  34. //查询Email类型的数据操作
  35. Cursor emails = contentResolver.query(ContactsContract.CommonDataKinds.Email.CONTENT_URI,
  36. null,
  37. ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = " + contactId,
  38. null, null);
  39. while (emails.moveToNext())
  40. {
  41. String emailAddress = emails.getString(emails.getColumnIndex(
  42. ContactsContract.CommonDataKinds.Email.DATA));
  43. //添加Email的信息
  44. sb.append(",Email=").append(emailAddress);
  45. }
  46. emails.close();
  47. Log.i(TAG, sb.toString());
  48. }
  49. cursor.close();
  50. }
  51. public void testInsert()
  52. {
  53. ContentValues values = new ContentValues();
  54. //首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
  55. Uri rawContactUri = this.getContext().getContentResolver().insert(RawContacts.CONTENT_URI, values);
  56. //获取id
  57. long rawContactId = ContentUris.parseId(rawContactUri);
  58. //往data表入姓名数据
  59. values.clear();
  60. values.put(Data.RAW_CONTACT_ID, rawContactId); //添加id
  61. values.put(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE);//添加内容类型(MIMETYPE)
  62. values.put(StructuredName.GIVEN_NAME, "凯风自南");//添加名字,添加到first name位置
  63. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  64. //往data表入电话数据
  65. values.clear();
  66. values.put(Data.RAW_CONTACT_ID, rawContactId);
  67. values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
  68. values.put(Phone.NUMBER, "13921009789");
  69. values.put(Phone.TYPE, Phone.TYPE_MOBILE);
  70. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  71. //往data表入Email数据
  72. values.clear();
  73. values.put(Data.RAW_CONTACT_ID, rawContactId);
  74. values.put(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
  75. values.put(Email.DATA, "kesenhoo@gmail.com");
  76. values.put(Email.TYPE, Email.TYPE_WORK);
  77. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  78. }
  79. public void testSave() throws Throwable
  80. {
  81. //官方文档位置:reference/android/provider/ContactsContract.RawContacts.html
  82. //建立一个ArrayList存放批量的参数
  83. ArrayList<ContentProviderOperation> ops = new ArrayList<ContentProviderOperation>();
  84. int rawContactInsertIndex = ops.size();
  85. ops.add(ContentProviderOperation.newInsert(RawContacts.CONTENT_URI)
  86. .withValue(RawContacts.ACCOUNT_TYPE, null)
  87. .withValue(RawContacts.ACCOUNT_NAME, null)
  88. .build());
  89. //官方文档位置:reference/android/provider/ContactsContract.Data.html
  90. //withValueBackReference后退引用前面联系人的id
  91. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  92. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  93. .withValue(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE)
  94. .withValue(StructuredName.GIVEN_NAME, "小明")
  95. .build());
  96. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  97. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  98. .withValue(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE)
  99. .withValue(Phone.NUMBER, "13671323809")
  100. .withValue(Phone.TYPE, Phone.TYPE_MOBILE)
  101. .withValue(Phone.LABEL, "手机号")
  102. .build());
  103. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  104. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  105. .withValue(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE)
  106. .withValue(Email.DATA, "kesen@gmail.com")
  107. .withValue(Email.TYPE, Email.TYPE_WORK)
  108. .build());
  109. ContentProviderResult[] results = this.getContext().getContentResolver()
  110. .applyBatch(ContactsContract.AUTHORITY, ops);
  111. for(ContentProviderResult result : results)
  112. {
  113. Log.i(TAG, result.uri.toString());
  114. }
  115. }
  116. }*******************************************************************************************************

这里主要使用的是

ContactsContract类

从Android 2.0 SDK开始有关联系人provider的类变成了ContactsContract,虽然老的android.provider.Contacts能用,但是在SDK中标记为为deprecated将被放弃不推荐的方法,而从Android 2.0及API Level为5开始新增了android.provider.ContactsContract来代替原来的方法。不过Android123表示大家做两手准备,毕竟目前70%的设备以及Ophone 1.0和1.5均不支持ContactsContract。

ContactsContract.Contacts中的所有字段

ContactsContract.Contracts实现了4个接口,并从4个接口中,继承了不同的字段,一共有23个如下:

1. ContactsContract.Contacts.TIMES_CONTACTED ="times_contacted"

The number of times a contact has been contacted

2. ContactsContract.Contacts.CONTACT_STATUS ="contact_status"

Contact's latest status update.

3. ContactsContract.Contacts.CUSTOM_RINGTONE ="custom_ringtone"

URI for a custom ringtone associated with the contact. Ifnull or missing, the default ringtone is used.

4. ContactsContract.Contacts.HAS_PHONE_NUMBER ="has_phone_number"

An indicator of whether this contact has at least one phonenumber. "1" if there is at least one phone number, "0"otherwise.

5. ContactsContract.Contacts.PHONETIC_NAME = "phonetic_name"

Pronunciation of the full name in the phonetic alphabetspecified by PHONETIC_NAME_STYLE.

6. ContactsContract.Contacts.PHONETIC_NAME_STYLE ="phonetic_name_style"

The phonetic alphabet used to represent the PHONETIC_NAME.See PhoneticNameStyle.

7. ContactsContract.Contacts.CONTACT_STATUS_LABEL ="contact_status_label"

The resource ID of the label describing the source ofcontact status, e.g. "Google Talk". This resource is scoped by theCONTACT_STATUS_RES_PACKAGE.

8. ContactsContract.Contacts.LOOKUP_KEY = "lookup"

An opaque value that contains hints on how to find thecontact if its row id changed as a result of a sync or aggregation.

9. ContactsContract.Contacts.CONTACT_STATUS_ICON ="contact_status_icon"

The resource ID of the icon for the source of contactstatus. This resource is scoped by the

CONTACT_STATUS_RES_PACKAGE.

10. ContactsContract.Contacts.LAST_TIME_CONTACTED= "last_time_contacted"

The last time a contact was contacted.

11. ContactsContract.Contacts.DISPLAY_NAME= "display_name"

The display name for the contact.

12. ContactsContract.Contacts.SORT_KEY_ALTERNATIVE= "sort_key_alt"

Sort key based on the alternative representation of thefull name, DISPLAY_NAME_ALTERNATIVE. Thus for Western names, it is the oneusing the "family name first" format.

13. ContactsContract.Contacts.IN_VISIBLE_GROUP= "in_visible_group"

Lookup value that reflects the GROUP_VISIBLE state of anyContactsContract.CommonDataKinds.GroupMembership for this contact.

14. ContactsContract.Contacts._ID= "_id"

The unique ID for a row.

15. ContactsContract.Contacts.STARRED= "starred"

Is the contact starred?

16. ContactsContract.Contacts.SORT_KEY_PRIMARY= "sort_key"

Sort key that takes into account locale-based traditionsfor sorting names in address books.

17. ContactsContract.Contacts.DISPLAY_NAME_ALTERNATIVE= "display_name_alt"

An alternative representation of the display name, such as"family name first" instead of "given name first" forWestern names. If an alternative is not available, the values should be thesame as DISPLAY_NAME_PRIMARY

18. ContactsContract.Contacts.CONTACT_PRESENCE= "contact_presence"

Contact presence status. See ContactsContract.StatusUpdatesfor individual status definitions.

19. ContactsContract.Contacts.DISPLAY_NAME_SOURCE= "display_name_source"

The kind of data that is used as the display name for thecontact, such as structured name or email address. See DisplayNameSources.TODO: convert DisplayNameSources to a link after it is un-hidden

20. ContactsContract.Contacts.CONTACT_STATUS_RES_PACKAGE= "contact_status_res_package"

The package containing resources for this status: label andicon.

21. ContactsContract.Contacts.CONTACT_STATUS_TIMESTAMP= "contact_status_ts"

The absolute time in milliseconds when the latest statuswas inserted/updated.

22. ContactsContract.Contacts.PHOTO_ID= "photo_id"

Reference to the row in the data table holding the photo.

23. ContactsContract.Contacts.SEND_TO_VOICEMAIL= "send_to_voicemail"

Whether the contact should always be sent to voicemail. Ifmissing, defaults to false.

 

可以用以下方法,列出ContactsContract.Contacts中的所有字段:

 

privatevoidlistColumnNames()

{

private Uri contactUri =ContactsContract.Contacts.CONTENT_URI;

ContentResolver resolver = this.getContentResolver();

Cursor cursor =resolver.query(contactUri, null,null, null,null);

int columnNumber = cursor.getColumnCount();

for(int i = 0; i <columnNumber; i++)

{

String temp =cursor.getColumnName(i);

Log.e("listColumnNames","" + i + "\t" + temp);

}

cursor.close();

}

来自:http://blog.sina.com.cn/s/blog_90cdca4c01010zm4.html

分享到:
评论

相关推荐

    Android2.0 中读取联系人——ContactsContract

    在Android 2.0及更高版本中,由于SDK对联系人数据的访问方式进行了更新,开发者需要使用新的API来读取和操作联系人信息。本文将详细介绍如何使用`ContactsContract`类来实现这一功能。 在Android 2.0之前,开发人员...

    android中ContactsContract获取联系人的方法

    总结起来,`ContactsContract`是Android系统中访问联系人数据的核心接口,通过`CursorLoader`和`Cursor`进行数据查询,结合不同的Uri和查询条件,可以实现对联系人列表、详细信息以及特定字段的检索。在实际开发中,...

    android 联系人排序,支持中文 demo

    总结,"android 联系人排序,支持中文 demo"涵盖了Android联系人API的使用、数据排序机制、中文字符处理、自定义排序规则以及性能优化等多个方面,是学习和解决Android中文联系人排序问题的重要参考。通过深入理解...

    Android-ContactsContract联系人增删改查

    在Android系统中, ContactsContract是访问和操作设备上联系人数据的核心API。它提供了一种统一的方式来与系统联系人数据库进行交互,无论这些联系人来自哪个应用或服务。本篇文章将深入探讨如何利用...

    Android-Android联系人选择器

    在Android应用开发中,"Android-Android联系人选择器"是一个常见的需求,它允许用户从他们的设备联系人列表中选择一个或多个联系人。这个功能广泛应用于消息发送、邀请发送等场景,提升用户体验并简化操作流程。在这...

    Android获取手机通讯录、sim卡联系人及调用拨号界面方法

    总结来说,Android开发中获取手机通讯录和SIM卡联系人信息,以及调用拨号界面,主要是通过Content Resolver查询系统提供的Content Provider,同时需要正确配置权限。理解并熟练运用这些方法,可以帮助开发者构建更...

    Android获取联系人

    在Android系统中,获取联系人信息是常见的功能需求,尤其对于社交类或通讯类应用来说,这是一项必不可少的功能。为了实现这一目标,开发者需要理解Android的权限管理、ContentResolver和ContactsContract类。以下是...

    android添加联系人

    `ContactsContract`类是Android提供的一个接口,用于访问和操作联系人数据。通过这个类,我们可以读取、写入、更新和删除联系人信息。 添加联系人通常涉及以下几个步骤: 1. **请求权限**:在AndroidManifest.xml...

    android 联系人模块例子

    下面我们将深入探讨这个话题,了解Android联系人API的使用以及如何构建联系人管理模块。 首先,Android的联系人数据存储在系统数据库中,开发者可以通过Content Provider接口进行访问。Content Provider是Android...

    android 联系人广播协议 代码

    本文将深入探讨Android联系人广播协议的相关知识点,并通过代码示例来帮助开发者理解其工作原理。 一、Android联系人广播事件 当用户在系统中添加、删除或修改联系人时,Android会发送一个Intent广播,这个广播携带...

    android 联系人详解

    Android联系人API概述 Android提供了一个丰富的API,允许开发者通过ContentResolver和ContentProvider与系统的联系人数据进行交互。主要涉及以下组件: - **ContentResolver**:这是应用程序与ContentProvider之间...

    android 联系人模块

    在Android平台上,联系人模块是应用开发中的一个重要组成部分,它允许用户管理他们的个人联系信息,如姓名、电话号码、电子邮件地址等。对于初学者来说,理解并实现这一功能可以帮助他们更好地掌握Android应用开发的...

    Android读取联系人代码示例

    ContactsContract类是Android提供的一个内容提供者接口,用于访问和修改联系人数据。以下是一个简单的代码示例,展示了如何查询并显示所有联系人的名字和电话号码: ```java // 获取ContentResolver实例 ...

    android合并重复联系人功能

    总的来说,"android合并重复联系人功能"是Android开发中的一个重要领域,它涉及到数据处理、算法设计、数据库操作以及用户交互等多个方面,通过这一功能的实现,我们可以显著提升Android设备的联系人管理效率。

    ContactsContract读取联系人的异步方法

    在Android系统中,ContactsContract是用于访问和操作设备上联系人数据的核心API。这篇博客“ContactsContract读取联系人的异步方法”深入探讨了如何利用这个API以非阻塞的方式获取用户联系人信息,这对于提高应用...

    Android系统联系人全特效实现,字母表快速滚动

    在实现联系人应用时,我们需要与`ContactsContract`类进行交互,它是Android提供的用于访问联系人数据的API。 接下来,我们关注核心的字母表快速滚动功能。这一特性通常通过一个侧边栏或者顶部栏显示字母表,并且当...

    android 批量插入联系人、短信、通话记录,安装版,apk格式

    在Android中,联系人通常存储在Content Provider中,由`ContactsContract`类提供接口进行访问和操作。短信则通过`SmsProvider`来管理,而通话记录则由`CallLog` Content Provider负责。自Android 4.4(KitKat)版本...

    android平台联系人管理应用源码+项目(项目直接导入可运行)

    本项目“android平台联系人管理应用源码+项目”提供了一个可以直接运行的实例,对于学习和理解Android联系人管理的实现机制非常有帮助。以下是基于这个项目的一些关键知识点和详细说明: 1. **Android开发环境**:...

    android 联系人 SIM卡 最近联系人 通讯录 获取源代码

    一、Android联系人管理 Android系统提供了ContentProvider接口来访问和操作联系人数据。主要涉及到以下几个核心类: 1. `ContactsContract`:这是Android系统提供的一个常量类,包含了所有关于联系人数据的URI、...

    Androidの联系人群组Group操作

    在Android操作系统中,联系人管理是一项重要的功能,它允许用户组织和管理个人及商务联系人的信息。本节将深入探讨Android中的联系人群组(Group)操作,这些操作通常涉及到编程接口的使用,以便在应用程序中实现...

Global site tag (gtag.js) - Google Analytics