iOS中的通讯录是存储在数据库中的,由于iOS的权限设计,开发人员是不允许直接访问通讯录数据库的,必须依靠AddressBook提供的标准API来实现通讯录操作。
有2个框架可以访问用户的通讯录:AddressBookUI.framework
提供了联系人列表界面、联系人详情界面、添加联系人界面等
一般用于选择联系人.AddressBook.framework
纯C语言的API,仅仅是获得联系人数据
没有提供UI界面展示,需要自己搭建联系人展示界面
里面的数据类型大部分基于Core Foundation框架,使用起来极其蛋疼,但是需要注意的是这个框架是基于C语言编写的,无法使用ARC来管理内存,开发者需要自己管理内存.
联系人属性定义
所有的属性常量值都定义在了ABPerson.h头文件中.
联系人属性包括以下类型:
- 简单属性:姓、名等
- 多重属性:电话号码、电子邮件等
- 组合属性:地址等
注意:使用ABRecordCopyValue可以从一条Person记录中获取到对应的记录,但是后续处理则需要根据记录的具体类型加以区分
简单属性
- 一个联系人就是一个
ABRecordRef
,每个联系人都有自己的属性,比如名字、电话、邮件等 - 使用
ABRecordCopyValue
函数可以从ABRecordRef
中获得联系人的简单属性(例如:一个字符串) ABRecordCopyValue
函数接收2个参数
第1个参数是ABRecordRef
实例
第2个参数是属性关键字,定义在ABPerson.h
中ABPersonCopyLocalizedPropertyName
函数可以根据指定的关键字获取对应的标签文本
添加联系人的步骤
- 通过
ABPersonCreate
函数创建一个新的联系人(返回ABRecordRef) - 通过
ABRecordSetValue
函数设置联系人的属性 - 通过
ABAddressBookAddRecord
函数将联系人添加到通讯录数据库中 - 通过
ABAddressBookSave
函数保存刚才所作的修改 - 可以通过
ABAddressBookHasUnsavedChanges
函数判断是否有未保存的修改 - 当决定是否更改通讯录数据库后,你可以分别使用
AbAddressBookSave
或ABAddressBookRevert
方式来保存或放弃更改
添加群组的步骤
- 通过ABPersonCreate函数创建一个新的组(返回ABRecordRef)
- 通过ABRecordSetValue函数设置组名
- 通过ABAddressBookAddRecord函数将组添加到通讯录数据库中
- 通过ABAddressBookSave函数保存刚才所作的修改
使用AddressBookUI
:
- (void)viewDidLoad {
[super viewDidLoad];
// 创建选择联系人的界面
ABPeoplePickerNavigationController *abVc = [[ABPeoplePickerNavigationController alloc] init];
// 设置代理
abVc.peoplePickerDelegate = self;
// 弹出选择联系人界面
[self presentViewController: abVc animated:YES completion:nil];
}
接下来实现代理方法
// 选中某一个联系人的时候,会执行该代理方法
// 如果实现了该方法,那么就不会进入联系人的详细界面
- (void)peoplePickerNavigationController:(ABPeoplePickerNavigationController *)peoplePicker didSelectPerson:(ABRecordRef)person {
/*
__bridge NSString * : 将CoreFoundation框架的对象所有权交给Foundation框架来使用,但是Foundation框架中的对象并不能管理该对象内存
__bridge_transfer NSString * : 将CoreFoundation框架的对象所有权交给Foundation来管理,如果Foundation中对象销毁,那么我们之前的对象(CoreFoundation)会一起销毁
*/
// 获取选中联系人的姓名(姓lastname和名firstname)
CFStringRef firstname = ABRecordCopyValue(person, kABPersonFirstNameProperty);
CFStringRef lastname = ABRecordCopyValue(person, kABPersonLastNameProperty);
NSString *firstName = (__bridge_transfer NSString *)(firstname);
NSString *lastName = (__bridge_transfer NSString *)(lastname);
NSLog(@"%@ %@", firstName, lastName);
// 获取联系人的电话号码
ABMultiValueRef phones = ABRecordCopyValue(person, kABPersonPhoneProperty);
CFIndex count = ABMultiValueGetCount(phones);
for (CFIndex i = 0; i < count; i++) {
NSString *phoneLabel = (__bridge_transfer NSString *)ABMultiValueCopyLabelAtIndex(phones, i);
NSString *phoneValue = (__bridge_transfer NSString *)ABMultiValueCopyValueAtIndex(phones, i);
NSLog(@"label : %@ value : %@", phoneLabel, phoneValue);
}
// 释放不再使用的对象
CFRelease(phones);
}
// 选择某一个联系人的某一个属性时,会执行该方法
// property选中的属性
// identifier : 每一个属性都由一个对应标示
// 如果实现了该方法,那么选中一个联系人的属性时,就会推出控制器.不会进入下一个页面
- (void)peoplePickerNavigationController:(ABPeoplePickerNavigationController *)peoplePicker didSelectPerson:(ABRecordRef)person property:(ABPropertyID)property identifier:(ABMultiValueIdentifier)identifier {
NSLog(@"选择了某一个联系人的某一个属性");
}
// 点击了取消按钮会执行该方法
- (void)peoplePickerNavigationControllerDidCancel:(ABPeoplePickerNavigationController *)peoplePicker {
}
使用AddressBook
:
// 获取授权的状态
ABAuthorizationStatus status = ABAddressBookGetAuthorizationStatus();
// 如果用户已经授权
if (status != kABAuthorizationStatusAuthorized) return;
// 创建通信录对象
ABAddressBookRef addressBook = ABAddressBookCreateWithOptions(NULL, NULL);
// 从通信录对象中,将所有的联系人拷贝出来
CFArrayRef peopleArray = ABAddressBookCopyArrayOfAllPeople(addressBook);
// 遍历所有的联系人(每一个联系人都是一条记录)
CFIndex peopleCount = CFArrayGetCount(peopleArray);
for (CFIndex i = 0; i < peopleCount; i++) {
// 获取到联系人
ABRecordRef person = CFArrayGetValueAtIndex(peopleArray, i);
// 获取姓名
NSString *lastname = (__bridge_transfer NSString *)ABRecordCopyValue(person, kABPersonLastNameProperty);
NSString *firstName = (__bridge_transfer NSString *)ABRecordCopyValue(person, kABPersonFirstNameProperty);
NSLog(@"%@ %@", lastname, firstName);
}
// 释放不再使用的对象
CFRelease(peopleArray);
CFRelease(addressBook);
本文作者:
Aeron_Xie
最后更新: 2023年03月25日 22:39:55
本文链接: http://aeronxie.github.io/post/30642c85.html
版权声明: 本作品采用 CC BY-NC-SA 4.0 许可协议进行许可,转载请注明出处!
最后更新: 2023年03月25日 22:39:55
本文链接: http://aeronxie.github.io/post/30642c85.html
版权声明: 本作品采用 CC BY-NC-SA 4.0 许可协议进行许可,转载请注明出处!