todos samsung por pasar los eliminar cómo contactos como objective-c ios ios6 abaddressbook

objective-c - samsung - pasar contactos de iphone a android por bluetooth



¿La libreta de direcciones iOS 6 no funciona? (4)

Mi método de recuperación programática de direcciones de correo electrónico desde la Libreta de direcciones ya no parece funcionar en dispositivos con iOS 6. Funcionó en iOS 5 y, curiosamente, todavía funciona en el simulador de iOS 6. ¿Hay alguna forma nueva de recuperar contactos desde la libreta de direcciones de un usuario mediante programación?

ABAddressBookRef addressBook = ABAddressBookCreate(); CFArrayRef allPeople = ABAddressBookCopyArrayOfAllPeople(addressBook); CFIndex nPeople = ABAddressBookGetPersonCount(addressBook); self.contacts = [[NSMutableArray alloc] init]; int contactIndex = 0; for (int i = 0; i < nPeople; i++) { // Get the next address book record. ABRecordRef record = CFArrayGetValueAtIndex(allPeople, i); // Get array of email addresses from address book record. ABMultiValueRef emailMultiValue = ABRecordCopyValue(record, kABPersonEmailProperty); NSArray *emailArray = (__bridge_transfer NSArray *)ABMultiValueCopyArrayOfAllValues(emailMultiValue); [self.contacts addObject:emailArray]; }

Para aclarar, lo anterior no falla, simplemente no devuelve resultados. ABAddressBookCopyArrayOfAllPeople está vacío. ¡Gracias!


Probablemente relacionado con los nuevos controles de privacidad: a partir de iOS 6, en el dispositivo, una aplicación no puede acceder a los contactos del usuario sin su permiso. De la documentación:

En iOS 6.0 y posterior, si la persona que llama no tiene acceso a la base de datos de la libreta de direcciones:

• Para aplicaciones vinculadas con iOS 6.0 y posterior, esta función devuelve NULL.

• Para aplicaciones vinculadas con versiones anteriores de iOS, esta función devuelve una base de datos de solo lectura vacía.

Si no ha visto aparecer la alerta de permisos ("SomeApp desea acceder a sus contactos"), es posible que las API de libreta de direcciones solo asuman que no tienen acceso y fallan silenciosamente; es posible que deba mostrar algo desde el marco AddressBookUI para activarlo.


Creé una clase auxiliar, AddressBookHelper , para gestionar la compatibilidad con versiones anteriores. Aquí están las agallas:

-(BOOL)isABAddressBookCreateWithOptionsAvailable { return &ABAddressBookCreateWithOptions != NULL; } -(void)loadContacts { ABAddressBookRef addressBook; if ([self isABAddressBookCreateWithOptionsAvailable]) { CFErrorRef error = nil; addressBook = ABAddressBookCreateWithOptions(NULL,&error); ABAddressBookRequestAccessWithCompletion(addressBook, ^(bool granted, CFErrorRef error) { // callback can occur in background, address book must be accessed on thread it was created on dispatch_async(dispatch_get_main_queue(), ^{ if (error) { [self.delegate addressBookHelperError:self]; } else if (!granted) { [self.delegate addressBookHelperDeniedAcess:self]; } else { // access granted AddressBookUpdated(addressBook, nil, self); CFRelease(addressBook); } }); }); } else { // iOS 4/5 addressBook = ABAddressBookCreate(); AddressBookUpdated(addressBook, NULL, self); CFRelease(addressBook); } } void AddressBookUpdated(ABAddressBookRef addressBook, CFDictionaryRef info, void *context) { AddressBookHelper *helper = (AddressBookHelper *)context; ABAddressBookRevert(addressBook); CFArrayRef people = ABAddressBookCopyArrayOfAllPeople(addressBook); // process the contacts to return NSArray *contacts = ... [[helper delegate] addressBookHelper:helper finishedLoading:contacts]; };


Intente con esto: se debe otorgar acceso a la libreta de direcciones antes de poder acceder mediante programación. Esto es lo que terminé haciendo.

#import <AddressBookUI/AddressBookUI.h> // Request authorization to Address Book ABAddressBookRef addressBookRef = ABAddressBookCreateWithOptions(NULL, NULL); if (ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusNotDetermined) { ABAddressBookRequestAccessWithCompletion(addressBookRef, ^(bool granted, CFErrorRef error) { // First time access has been granted, add the contact [self _addContactToAddressBook]; }); } else if (ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusAuthorized) { // The user has previously given access, add the contact [self _addContactToAddressBook]; } else { // The user has previously denied access // Send an alert telling user to change privacy setting in settings app }


Probablemente relacionado con los nuevos controles de privacidad, a partir de iOS 6, en el dispositivo, una aplicación no puede acceder a los contactos del usuario sin su permiso.

Código:

-(void)addressBookValidation { NSUserDefaults *prefs=[NSUserDefaults standardUserDefaults]; ABAddressBookRef addressbook = ABAddressBookCreate(); __block BOOL accessGranted = NO; if (ABAddressBookRequestAccessWithCompletion != NULL) { if (ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusNotDetermined) { dispatch_semaphore_t sema = dispatch_semaphore_create(0); ABAddressBookRequestAccessWithCompletion(addressbook, ^(bool granted, CFErrorRef error) { accessGranted = granted; dispatch_semaphore_signal(sema); }); dispatch_semaphore_wait(sema, DISPATCH_TIME_FOREVER); dispatch_release(sema); } else if(ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusAuthorized) { accessGranted = YES; } else if (ABAddressBookGetAuthorizationStatus()==kABAuthorizationStatusDenied) { accessGranted = NO; } else if (ABAddressBookGetAuthorizationStatus()==kABAuthorizationStatusRestricted){ accessGranted = NO; } else { accessGranted = YES; } } else { accessGranted = YES; } [prefs setBool:accessGranted forKey:@"addressBook"]; NSLog(@"[prefs boolForKey:@''addressBook'']--->%d",[prefs boolForKey:@"addressBook"]); [prefs synchronize]; CFRelease(addressbook); }