ios之通讯录 ios9和ios10

iOS通讯录权限申请与使用

由于系统的通讯录在iOS9的时候提供了新的api,所以我们2种框架都使用。首先我们要导入框架

[objc]  view plain  copy
  1. /// iOS 9前的框架  
  2. #import <AddressBook/AddressBook.h>  
  3. #import <AddressBookUI/AddressBookUI.h>  
  4. /// iOS 9的新框架  
  5. #import <ContactsUI/ContactsUI.h>  
[objc]  view plain  copy
  1. #define Is_up_Ios_9             ([[UIDevice currentDevice].systemVersion floatValue] >= 9.0  
[objc]  view plain  copy
  1. @interface ViewController : UIViewController<ABPeoplePickerNavigationControllerDelegate,CNContactPickerDelegate>  


接着在需要调用通讯录的vc里面添加一下代码

[objc]  view plain  copy
  1. #pragma mark ---- 调用系统通讯录  
  2. - (void)JudgeAddressBookPower {  
  3.     ///获取通讯录权限,调用系统通讯录  
  4.     [self CheckAddressBookAuthorization:^(bool isAuthorized , bool isUp_ios_9) {  
  5.         if (isAuthorized) {  
  6.             [self callAddressBook:isUp_ios_9];  
  7.         }else {  
  8.             NSLog(@"请到设置>隐私>通讯录打开本应用的权限设置");  
  9.         }  
  10.     }];  
  11. }  
  12.       
  13. - (void)CheckAddressBookAuthorization:(void (^)(bool isAuthorized , bool isUp_ios_9))block {  
  14.     if (Is_up_Ios_9) {  
  15.         CNContactStore * contactStore = [[CNContactStore alloc]init];  
  16.         if ([CNContactStore authorizationStatusForEntityType:CNEntityTypeContacts] == CNAuthorizationStatusNotDetermined) {  
  17.             [contactStore requestAccessForEntityType:CNEntityTypeContacts completionHandler:^(BOOL granted, NSError * __nullable error) {  
  18.                 if (error)  
  19.                 {  
  20.                     NSLog(@"Error: %@", error);  
  21.                 }  
  22.                 else if (!granted)  
  23.                 {  
  24.                       
  25.                     block(NO,YES);  
  26.                 }  
  27.                 else  
  28.                 {  
  29.                     block(YES,YES);  
  30.                 }  
  31.             }];  
  32.         }  
  33.         else if ([CNContactStore authorizationStatusForEntityType:CNEntityTypeContacts] == CNAuthorizationStatusAuthorized){  
  34.             block(YES,YES);  
  35.         }  
  36.         else {  
  37.             NSLog(@"请到设置>隐私>通讯录打开本应用的权限设置");  
  38.         }  
  39.     }else {  
  40.         ABAddressBookRef addressBook = ABAddressBookCreateWithOptions(NULLNULL);  
  41.         ABAuthorizationStatus authStatus = ABAddressBookGetAuthorizationStatus();  
  42.           
  43.         if (authStatus == kABAuthorizationStatusNotDetermined)  
  44.         {  
  45.             ABAddressBookRequestAccessWithCompletion(addressBook, ^(bool granted, CFErrorRef error) {  
  46.                 dispatch_async(dispatch_get_main_queue(), ^{  
  47.                     if (error)  
  48.                     {  
  49.                         NSLog(@"Error: %@", (__bridge NSError *)error);  
  50.                     }  
  51.                     else if (!granted)  
  52.                     {  
  53.                           
  54.                         block(NO,NO);  
  55.                     }  
  56.                     else  
  57.                     {  
  58.                         block(YES,NO);  
  59.                     }  
  60.                 });  
  61.             });  
  62.         }else if (authStatus == kABAuthorizationStatusAuthorized)  
  63.         {  
  64.             block(YES,NO);  
  65.         }else {  
  66.             NSLog(@"请到设置>隐私>通讯录打开本应用的权限设置");  
  67.         }  
  68.     }  
  69. }  
  70.       
  71. - (void)callAddressBook:(BOOL)isUp_ios_9 {  
  72.     if (isUp_ios_9) {  
  73.         CNContactPickerViewController *contactPicker = [[CNContactPickerViewController alloc] init];  
  74.         contactPicker.delegate = self;  
  75.         contactPicker.displayedPropertyKeys = @[CNContactPhoneNumbersKey];  
  76.         [self presentViewController:contactPicker animated:YES completion:nil];  
  77.     }else {  
  78.         ABPeoplePickerNavigationController *peoplePicker = [[ABPeoplePickerNavigationController alloc] init];  
  79.         peoplePicker.peoplePickerDelegate = self;  
  80.         [self presentViewController:peoplePicker animated:YES completion:nil];  
  81.   
  82.     }  
  83. }  
  84.   
  85. #pragma mark -- CNContactPickerDelegate  
  86. - (void)contactPicker:(CNContactPickerViewController *)picker didSelectContactProperty:(CNContactProperty *)contactProperty {  
  87.     CNPhoneNumber *phoneNumber = (CNPhoneNumber *)contactProperty.value;  
  88.     [self dismissViewControllerAnimated:YES completion:^{  
  89.         /// 联系人  
  90.         NSString *text1 = [NSString stringWithFormat:@"%@%@",contactProperty.contact.familyName,contactProperty.contact.givenName];  
  91.         /// 电话  
  92.         NSString *text2 = phoneNumber.stringValue;  
  93. //        text2 = [text2 stringByReplacingOccurrencesOfString:@"-" withString:@""];  
  94.         NSLog(@"联系人:%@, 电话:%@",text1,text2);  
  95.     }];  
  96. }  
  97.   
  98. #pragma mark -- ABPeoplePickerNavigationControllerDelegate  
  99. - (void)peoplePickerNavigationController:(ABPeoplePickerNavigationController*)peoplePicker didSelectPerson:(ABRecordRef)person property:(ABPropertyID)property identifier:(ABMultiValueIdentifier)identifier {  
  100.       
  101.     ABMultiValueRef valuesRef = ABRecordCopyValue(person, kABPersonPhoneProperty);  
  102.     CFIndex index = ABMultiValueGetIndexForIdentifier(valuesRef,identifier);  
  103.     CFStringRef value = ABMultiValueCopyValueAtIndex(valuesRef,index);  
  104.     CFStringRef anFullName = ABRecordCopyCompositeName(person);  
  105.       
  106.     [self dismissViewControllerAnimated:YES completion:^{  
  107.         /// 联系人  
  108.         NSString *text1 = [NSString stringWithFormat:@"%@",anFullName];  
  109.         /// 电话  
  110.         NSString *text2 = (__bridge NSString*)value;  
  111. //        text2 = [text2 stringByReplacingOccurrencesOfString:@"-" withString:@""];  
  112.         NSLog(@"联系人:%@, 电话:%@",text1,text2);  
  113.     }];  
  114. }  

最后我们可以调用  [ self   JudgeAddressBookPower ]; 就能简单的调用系统通讯录。


tips:如果要适配iOS 10,就必须在plist文件的Source code模式下添加

[objc]  view plain  copy
  1. <key>NSContactsUsageDescription</key>  
  2. <string>App需要您的同意,才能访问通讯录</string>  
内容概要:本文提出了一种基于融合鱼鹰算法柯西变异的改进麻雀优化算法(OCSSA),用于优化变分模态分解(VMD)的参数,进而结合卷积神经网络(CNN)与双向长短期记忆网络(BiLSTM)构建OCSSA-VMD-CNN-BILSTM模型,实现对轴承故障的高【轴承故障诊断】基于融合鱼鹰柯西变异的麻雀优化算法OCSSA-VMD-CNN-BILSTM轴承诊断研究【西储大学数据】(Matlab代码实现)精度诊断。研究采用西储大学公开的轴承故障数据集进行实验验证,通过优化VMD的模态数惩罚因子,有效提升了信号分解的准确性与稳定性,随后利用CNN提取故障特征,BiLSTM捕捉时间序列的深层依赖关系,最终实现故障类型的智能识别。该方法在提升故障诊断精度与鲁棒性方面表现出优越性能。; 适合人群:具备一定信号处理、机器学习基础,从事机械故障诊断、智能运维、工业大数据分析等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①解决传统VMD参数依赖人工经验选取的问题,实现参数自适应优化;②提升复杂工况下滚动轴承早期故障的识别准确率;③为智能制造与预测性维护提供可靠的技术支持。; 阅读建议:建议读者结合Matlab代码实现过程,深入理解OCSSA优化机制、VMD信号分解流程以及CNN-BiLSTM网络架构的设计逻辑,重点关注参数优化与故障分类的联动关系,并可通过更换数据集进一步验证模型泛化能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值