访问地址簿和单个联系人数据的接口是基于C语言的函数,接口传递对地址簿各种对象的引用作为参数。管理地址簿中条目的基类对象是 ABRecord。一个 ABRecord 可以表示一个人 或者一个群体 ABGroup 。无论何时,在界面上选中一条记录,或者使用框架进行查询返回一条结果,系统都会返回一个指向 ABRecord 的指针,标示为 ABRecordRef。与地址簿 API 的大部分交互都涉及使用 ABRecordRef 这个引用类型。

常用访问记录的函数如下:

ABRecordID ABRecordGetRecord(ABRecordRef record);

返回 ABRecordID ,代表了 记录在底层数据库中的ID号。具有唯一性。

ABRecordType ABRecordGetRecordType(ABRecordRef record);

返回记录类型。可以是 kABPersonType 和 kABGroupType

CFStringRef ABRecordCopyCompositeName(ABRecordRef record);

返回个人或群体完整名称。例:NSString* name = (NSString*)ABRecordCopyCompositeName(record);

一、高层地址簿函数

1.获得地址簿句柄

你必须先初始化地址簿,然后才能对其进读写操作。要获得一个地址簿句柄,可以使用 ABAddressBookCreate函数:

[java] view plaincopyprint?
  1. #import <AddressBook/AddressBook.h>
  2. AddressBookRef ab = AddressBookCreate();

2. 保存地址簿

获得了地址簿的引用就可以对其进行操作了,操作完毕要记得保存:

[java] view plaincopyprint?
  1. CFErrorRef err;
  2. BOOL success =  ABAddressBookSave(ab, &err);

如果不确定是否需要保存,则可以用:

[java] view plaincopyprint?
  1. BOOL hasUnsavedChanges = ABAddressBookHasUnsavedChanges(ab);

3.添加/删除 记录

[java] view plaincopyprint?
  1. CFErrorRef err;
  2. BOOL success =ABAddressBookAddRecord(ab, record, &err);//添加
[java] view plaincopyprint?
  1. CFErrorRef err;
  2. BOOL success =ABAddressBookRemoveRecord(ab, record, &err);//删除

二、查询地址簿

地址簿框架仅仅提供了基本的查询功能。可以用函数根据名字来查询多个记录,或者是根据特定记录 ID 查询单个记录。

1.获取地址簿中记录总个数:

[java] view plaincopyprint?
  1. CFIndex count = ABAddressBookGetPersonCount(ab);
  2. printf("%ld total entries in the address book\n",count);

2. 获取所有联系人:

[java] view plaincopyprint?
  1. NSArray* array = (NSArray*)ABAddressBookCopyArrayOfAllPeople(ab);
  2. printf("Retrieved %d contacts\n",[array count]);

3. 在联系人列表中查询一个特定的名字:

[java] view plaincopyprint?
  1. NSArray* arrayByName = (NSArray*)ABAddressBookCopyPeopleWithName(ab, CFSTR("Liu Wei"));

函数如其名,这个函数返回的并不是地址簿中实际的对象,而是拷贝。要访问这个数组的单个记录,就用NSArray的方法啦:

[java] view plaincopyprint?
  1. ABRecordRef myRecord = [arrayByName objectAtIndex:0];

除了通过名字查询,你也可以直接通过ID查询(假如你知道ID的话):

[java] view plaincopyprint?
  1. ABRecordRef myRecord = ABAddressBookGetPersonWithRecordID(ab, recordID);

三、创建记录

创建新的联系人可以使用 ABPersonCreate 函数。这样可以得到一个空记录,然后就可以向其中填充信息:

[java] view plaincopyprint?
  1. ABRecordRef record = ABPersonCreate();

四、操纵记录

一旦获得了 ABRecordRef,就可以确定是属于个人还是群体,也就可以访问更进一步的信息了。姓名以及其他各项信息都可以通过相应属性来操纵。只有ABPerson 类型实体记录才会有属性,而每个记录都具有各种各样的信息。

查询给定记录的信息,可以使用 ABRecordCopyValue 函数。这个函数原型如下:

[java] view plaincopyprint?
  1. CFTypeRef ABRecordCopyValue(ABRecordRef record,kABPersonFirstNameProperty);

调用这个函数时,会将你指定 的属性拷贝一份,并返回引用:

[java] view plaincopyprint?
  1. CFStringRef firstName = ABRecordCopyValue(record, kABPersonFirstNameProperty);

由于kABPersonFirstNameProperty 属性是一个 CFString,你可以将其转换为 NSString* :

[java] view plaincopyprint?
  1. NSString* firstName =NSString* ABRecordCopyValue(record, kABPersonFirstNameProperty);

就像CFStringRef 可以转换为 NSString* 一样,如果有属性返回类型是CFDateRef,你也可以转换为 NSDate* :

[java] view plaincopyprint?
  1. NSDate* birthday =  (NSDate*) ABRecordCopyValue(record, kABPersonBirthdayProperty);

上面所指定的 ABPropertyID, 是一个与在记录中查找信息相对应的值。根据这个值返回ABPerson 对象属性。由于 ABRecordCopyValue 函数返回的数据类型是通用的 CFTypeRef ,所以结果可疑被转换为一个与属性相对应的更细化的数据类型,如下表:

[java] view plaincopyprint?
  1. // Property keys
  2. extern const ABPropertyID kABPersonFirstNameProperty;          // First name - kABStringPropertyType
  3. extern const ABPropertyID kABPersonLastNameProperty;           // Last name - kABStringPropertyType
  4. extern const ABPropertyID kABPersonMiddleNameProperty;         // Middle name - kABStringPropertyType
  5. extern const ABPropertyID kABPersonPrefixProperty;             // Prefix ("Sir" "Duke" "General") - kABStringPropertyType
  6. extern const ABPropertyID kABPersonSuffixProperty;             // Suffix ("Jr." "Sr." "III") - kABStringPropertyType
  7. extern const ABPropertyID kABPersonNicknameProperty;           // Nickname - kABStringPropertyType
  8. extern const ABPropertyID kABPersonFirstNamePhoneticProperty;  // First name Phonetic - kABStringPropertyType
  9. extern const ABPropertyID kABPersonLastNamePhoneticProperty;   // Last name Phonetic - kABStringPropertyType
  10. extern const ABPropertyID kABPersonMiddleNamePhoneticProperty; // Middle name Phonetic - kABStringPropertyType
  11. extern const ABPropertyID kABPersonOrganizationProperty;       // Company name - kABStringPropertyType
  12. extern const ABPropertyID kABPersonJobTitleProperty;           // Job Title - kABStringPropertyType
  13. extern const ABPropertyID kABPersonDepartmentProperty;         // Department name - kABStringPropertyType
  14. extern const ABPropertyID kABPersonEmailProperty;              // Email(s) - kABMultiStringPropertyType
  15. extern const ABPropertyID kABPersonBirthdayProperty;           // Birthday associated with this person - kABDateTimePropertyType
  16. extern const ABPropertyID kABPersonNoteProperty;               // Note - kABStringPropertyType
  17. extern const ABPropertyID kABPersonCreationDateProperty;       // Creation Date (when first saved)
  18. extern const ABPropertyID kABPersonModificationDateProperty;   // Last saved date

五、写入属性

向记录写入属性,使用ABRecordSetValue 函数:

[java] view plaincopyprint?
  1. CFStringRef name = CFSTR("IUKEY");
  2. BOOL suc = ABRecordSetValue(record, kABPersonNicknameProperty, name, &err);
  3. if (suc) {
  4. NSLog(@"setValue succeed");
  5. }

删除属性:

[java] view plaincopyprint?
  1. BOOL succeed = ABRecordRemoveValue(record, kABPersonFirstNameProperty, &err);

当修改完以后不要忘记保存地址簿。

六、多值属性

除了前面列出的属性之外,一个记录还可能会有一些属性,其中包含多个值。多只属性可以用一种索引机制来处理,使用时首先查询值的总数,然后通过特定的索引得到一个条目。指向多值数据的指针,可以首先通过前面提到的 ABRecordCopyValue 方法得到,然后转换成 MultiValueRef :

[java] view plaincopyprint?
  1. ABMultiValueRef phoneNumbers = ABRecordCopyValue(record, kABPersonPhoneProperty);

然后你可以通过这个引用来确定值的个数,并按照索引获取其中的单个值。函数ABMultiGetCount 可以返回条目个数,按照索引拷贝指定条目,可以用ABMultiValueCopyValueAtIndex 函数。

下面列出了多值属性中的条目:

[java] view plaincopyprint?
  1. extern const ABPropertyID kABPersonEmailProperty;
  2. extern const ABPropertyID kABPersonAddressProperty;
  3. extern const ABPropertyID kABPersonDateProperty;
  4. extern const ABPropertyID kABPersonPhoneProperty;
  5. extern const ABPropertyID kABPersonInstantMessageProperty;
  6. extern const ABPropertyID kABPersonURLProperty;

除了多值属性中真正的值,每个条目还有一个标签。标签描述了返回的条目的类型。例如,一个电话号码标签有可能指明了这个号码是家庭电话还是手机号。地址的标签则可一描述是家庭地址还是工作地址。要查询特定条目标签,可以使用 ABMultValueCopyLabelAtIndex 函数:

[java] view plaincopyprint?
  1. CFStringRef label = ABMultiValueCopyLabelAtIndex(phoneNumbers, i);

默写属性具有一组预定义的标签。下面这些 CFStringRef 类型标签的原型是在 ABPerson.h 中指定的:

[java] view plaincopyprint?
  1. extern const ABPropertyID kABPersonDateProperty;               // Dates associated with this person - kABMultiDatePropertyType
  2. extern const CFStringRef kABPersonAnniversaryLabel;
[java] view plaincopyprint?
  1. // Phone numbers
  2. extern const ABPropertyID kABPersonPhoneProperty;              // Generic phone number - kABMultiStringPropertyType
  3. extern const CFStringRef kABPersonPhoneMobileLabel;
  4. extern const CFStringRef kABPersonPhoneIPhoneLabel __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_3_0);
  5. extern const CFStringRef kABPersonPhoneMainLabel;
  6. extern const CFStringRef kABPersonPhoneHomeFAXLabel;
  7. extern const CFStringRef kABPersonPhoneWorkFAXLabel;
  8. extern const CFStringRef kABPersonPhoneOtherFAXLabel __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_5_0);
  9. extern const CFStringRef kABPersonPhonePagerLabel;
[java] view plaincopyprint?
  1. // IM
  2. extern const ABPropertyID kABPersonInstantMessageProperty;     // Instant Messaging - kABMultiDictionaryPropertyType
  3. extern const CFStringRef kABPersonInstantMessageServiceKey;     // Service ("Yahoo", "Jabber", etc.)
  4. extern const CFStringRef kABPersonInstantMessageServiceYahoo;
  5. extern const CFStringRef kABPersonInstantMessageServiceJabber;
  6. extern const CFStringRef kABPersonInstantMessageServiceMSN;
  7. extern const CFStringRef kABPersonInstantMessageServiceICQ;
  8. extern const CFStringRef kABPersonInstantMessageServiceAIM;
[java] view plaincopyprint?
  1. // URLs
  2. extern const ABPropertyID kABPersonURLProperty;                // URL - kABMultiStringPropertyType
  3. extern const CFStringRef kABPersonHomePageLabel; // Home Page
[java] view plaincopyprint?
  1. // Related names
  2. extern const ABPropertyID kABPersonRelatedNamesProperty;       // Names - kABMultiStringPropertyType
  3. extern const CFStringRef kABPersonFatherLabel;    // Father
  4. extern const CFStringRef kABPersonMotherLabel;    // Mother
  5. extern const CFStringRef kABPersonParentLabel;    // Parent
  6. extern const CFStringRef kABPersonBrotherLabel;   // Brother
  7. extern const CFStringRef kABPersonSisterLabel;    // Sister
  8. extern const CFStringRef kABPersonChildLabel;      // Child
  9. extern const CFStringRef kABPersonFriendLabel;    // Friend
  10. extern const CFStringRef kABPersonSpouseLabel;    // Spouse
  11. extern const CFStringRef kABPersonPartnerLabel;   // Partner
  12. extern const CFStringRef kABPersonAssistantLabel; // Assistant
  13. extern const CFStringRef kABPersonManagerLabel;   // Manager

许多属性使用一组通用标签,标识工作、家庭以及其它地点。这些通用的标签如下:

kABWorkLabel

kABHomeLabel

kABOtherLabel

写入多只属性条目:

为了在现有的属性中加入一个值,你必须首先从记录中复制出多值字典。然后 ABMultiValueAddValueAndLabel 函数操作拷贝,将新的值-标签加入到字典中。最后用函数 ABRecordSetValue 将字典条目写回到地址簿记录中,完全替换掉整个多值属性。

七、使用字典

地址簿记录用字典来 表示地址和即时通讯账号。这些字典是内嵌在多值属性条目之中的。要访问这些字典,需要将值复制出来,并转换成 NSDictionary* 。然后你就可以用一组预定于的键值来访问字典了。

八、图像数据

某些联系人可能会有与之相关联的图像。可以使用 ABPersonCopyImageData 函数获取这些图像数据,返回将是一个 CFDataRef。可以把它转换成 NSData*,然后用来初始化一个UIImage对象。

[java] view plaincopyprint?
  1. if (ABPersonHasImageData(record)) {
  2. UIImage *addressVookImage = [UIImage imageWithData:(NSData*)ABPersonCopyImageData(record)];
  3. }

九、地址簿界面

地址簿界面框架提供了两种关键的用户界面:一个“找人”导航控件,来选择联系人;以及一个视图控件,用于显示单个联系人。

1. 联系人视图

ABPersonViewController 提供了一个简单的界面,可以向用户显示一个联系人。联系人视图需要一个 CFRecordRef 。

[java] view plaincopyprint?
  1. ABPersonViewController *viewController = [[ABPersonViewController alloc]init];

可以将希望显示的记录赋值给 displayedPerson 属性:

[java] view plaincopyprint?
  1. viewController.displayedPerson=record;

然后,你可以创建一个数组,其中包含你想要显示给用户的属性。只有指定的属性才会被显示出来,不过如果联系人被修改了,所有属性都将显示出来。可用的属性值与前面提到的枚举值相同。每个都作为一个 NSNumber 对象加入到数组中。

[java] view plaincopyprint?
  1. NSMutableArray* properties = [[NSMutableArray alloc]init];
  2. [properties addObject:[NSNumber numberWithInt:kABPersonFirstNameProperty ]];
  3. [properties addObject:[NSNumber numberWithInt:kABPersonLastNameProperty ]];
  4. [properties addObject:[NSNumber numberWithInt:kABPersonOrganizationProperty ]];
  5. viewController.allowsEditing =YES;

十、联系人选取器

如果应用程序要选取一系列联系人,ABPeoplePickerNavigationController 类正好适合你。这个导航控件 可以显示联系人,让用户从中选择其一。选好后,你可以选择向用户显示该联系人,也可以通过一个委托方法实现你自己的行为。

[java] view plaincopyprint?
  1. ABPeoplePickerNavigationController* peoplePicker = [[ABPeoplePickerNavigationController alloc]init];

如果希望允许用户查看单个联系人,你可以赋予其一组希望用户看到的属性。默认情况下会向用户显示所有的项目。 可用的属性值就是本章前面讲授的那些枚举值。每个作为一个NSNumber对象加入到数组中:

[java] view plaincopyprint?
  1. NSMutableArray* properties = [[NSMutableArray alloc]init];
  2. [properties addObject:[NSNumber numberWithInt:kABPersonFirstNameProperty ]];
  3. [properties addObject:[NSNumber numberWithInt:kABPersonLastNameProperty ]];
  4. [properties addObject:[NSNumber numberWithInt:kABPersonOrganizationProperty ]];
  5. peoplePicker.displayedProperties = properties;

可以指定一个委托,在用户选定联系人时接收通知:

[java] view plaincopyprint?
  1. peoplePicker.peoplePickerDelegate =self;
[java] view plaincopyprint?
  1. [self.view addSubview:peoplePicker.view];

委托方发:

[java] view plaincopyprint?
  1. -(void)peoplePickerNavigationControllerDidCancel:(ABPeoplePickerNavigationController *)peoplePicker{
  2. //取消选择
  3. }
  4. -(BOOL)peoplePickerNavigationController:(ABPeoplePickerNavigationController *)peoplePicker shouldContinueAfterSelectingPerson:(ABRecordRef)person{
  5. //选中联系人
  6. }
  7. -(BOOL)peoplePickerNavigationController:(ABPeoplePickerNavigationController *)peoplePicker shouldContinueAfterSelectingPerson:(ABRecordRef)person property:(ABPropertyID)property identifier:(ABMultiValueIdentifier)identifier{
  8. //选中属性
  9. }

AddressBook 地址簿 (电话簿) 访问与修改相关推荐

  1. AddressBook 地址簿  (电话簿) 访问与修改-IOS开发

    访问地址簿和单个联系人数据的接口是基于C语言的函数,接口传递对地址簿各种对象的引用作为参数.管理地址簿中条目的基类对象是 ABRecord.一个 ABRecord 可以表示一个人 或者一个群体 ABG ...

  2. AddressBook 地址簿 (电话簿) 访问与修改-IOS开发

    访问地址簿和单个联系人数据的接口是基于C语言的函数,接口传递对地址簿各种对象的引用作为参数.管理地址簿中条目的基类对象是 ABRecord.一个 ABRecord 可以表示一个人 或者一个群体 ABG ...

  3. 在程序中集成地址簿、电子邮件和地图功能

    地址簿 iOS通过两个框架提供了全面的地址簿数据库访问功能:Address Book和Address Book UI. Address Book UI框架是一组用户界面类,封装了Address Boo ...

  4. 企业电子邮件系统全局地址簿管理及使用方法介绍

    大型公司企业,往往部门庞杂,组织架构复杂,企业中全局地址簿要做到智能化安全统一管理,权限划分清晰,更要求客户端用户的个人联系人地址薄管理整齐划一,操作界面美观,符合广大用户的使用习惯等要求.要满足这些 ...

  5. .Net/C# 实现: FlashFXP 地址簿中站点密码的加解密算法

    参阅 CCFer & TLFer : kanbol 的 Java 代码翻译修改而成: kanbol 说: 之前在TLF写过一个程序自动更新flashfxp的地址簿,也就是修改sites.dat ...

  6. 强制更新LYNC客户端的地址簿

    有的时候我们对LYNC的地址簿文件作了修改,对于服务器上的我们可以利用Update-csAddressBook来立即更新地址簿文件,但是对于客户端就没有那么容易了,从OCS R2以后,客户端就被定义为 ...

  7. python编程:电话簿TeleAddressBook和邮箱地址簿EmailAddressBook两个文件,合并为一个完整的AddressBook文件

    有电话簿TeleAddressBook和邮箱地址簿EmailAddressBook两个文件,使用字典结构将其合并为一个完整的AddressBook文件 . 变为: 代码如下: # -*- coding ...

  8. Mac OS X地址簿编程指南

    Address Book Programming Guide for Mac OS X 一.简介 地址簿是一种围绕联系人和组信息中心数据.可以查看这些信息应用程序.以及在程序中访问这些信息的编程接口的 ...

  9. 使用ABP vNext在5分钟内开发地址簿应用程序

    ABP vNext框架(以下称为" ABP")是由Volosoft设计的艺术品级应用程序开发框架.它基于域驱动设计(DDD),并创新地采用模块化开发设计.毫无疑问,ABP是ASP. ...

最新文章

  1. css 动态rem_【面试题】CSS知识点整理(附答案)
  2. CSS3的绝对定位与相对定位
  3. 【html、css、jq】制作一个简洁的音乐播放器
  4. 逻辑门电路的知识点归纳
  5. popoverController(iPad)
  6. python 计算每日累计_5分钟学会用Python可视化数据分析美股
  7. android自定义弹出框样式实现
  8. Java中构造方法的执行顺序
  9. android studio ndk 开发入门
  10. 幻想影院添加html渲染,幻想影院无毒版-幻想影院清爽版预约 _5577安卓网
  11. Linux时间戳和标准时间的互转
  12. 正则表达式学习实践心得——来源于codesheep(羊哥)
  13. IT路要如何走?——老程序员的10个忠告 .
  14. GPU-CUDA编程学习(四)-共享内存
  15. 正则表达式(Regular Expression)——入门笔记(常用正则表达式符号、正则表达式在线调试工具)
  16. 一文教你掌握广义估计方程
  17. 我的世界服务器物品属性,[娱乐|机械]Item Lore Stats —— 自定义你的物品属性[自带强化][1.10及以上]...
  18. 公司招聘专员爆头痛哭,求职者再拒绝我的邀请我就要。。。
  19. Python 绘制反高斯光束光强分布
  20. 联想计算机网络同传速度很慢,使用网络同传时传输速度特别慢怎么回事?知识点分析及操作步骤...

热门文章

  1. 去哪儿2017校园招聘笔试题
  2. Oracle Data Guard的三种保护模式
  3. 6.亿级流量电商详情页系统实战
  4. 关于Windows Paint的基础图层透明背景的操作说明
  5. 网络组建大全(包括企业网、校园网、网吧和基础知识)(转)
  6. ldac_aptx和aptx hd功能介绍及区别介绍
  7. Debian 安装 ldac
  8. 输入五个城市从小到大排序-c语言
  9. strtotime 用法
  10. 读取嫦娥4号探月雷达2B公开数据