ma1*_*w28 7 uitableview abaddressbook abpeoplepickerview ios
我想构建一个ContactsTableViewController类似GroupMe的东西.它显示了我的所有地址簿联系人,甚至是GroupMe用户.

似乎ABPeoplePickerNavigationController无法自定义.
那么,如果我使用ABAddressBook&访问地址簿联系人,ABPerson用自定义显示它们的最佳方式是UITableViewController什么?
我不想只是将所有地址簿联系人加载到一个,NSArray因为这可能会破坏内存(我知道在他们的手机上有数千个地址簿联系人的人.).我习惯使用Core Data和NSFetchedResultsController像这样的大型结果集.但是,要做到这一点,我必须ABPerson在Core Data中创建一个模型,这很容易,但保持与地址簿同步似乎具有挑战性和愚蠢.
将GroupMe联系人与地址簿联系人关联/链接的最佳方式是什么?
在尝试重新创建这个GroupMe风格的界面时,还有什么我应该知道/考虑的吗?
小智 20
我是GroupMe iOS开发人员之一,这就是我们的工作.
我们扫描用户地址簿并将其存储在Core Data中.我们有一个Contact对象,它具有1对多的电话号码,以及1对多的电子邮件地址.如果有很多接触,但在后续每次扫描中,我们忽略任何第一次扫描可能需要一点时间ABRecordRef,有一个kABPersonModificationDateProperty我们的最后一次扫描之前.这使得更新速度更快.
然后,假设用户已选择同步联系人,我们会将电话号码和电子邮件地址上传到我们的服务器,该服务器将与现有的GroupMe用户匹配.
最后,我们根据匹配(来自电话,电子邮件,脸书,推特)拉取GroupMe关系,并将这些关系存储在Core Data中.如果由于用户的地址簿中已存在电话/电子邮件而建立关系,我们会将这些值传递回关系中,以便我们可以在GroupMe关系与我们存储在Core Data中的联系人之间建立一对一的关系.步骤1.通过这种方式,我们可以轻松地NSFetchRequest为本地联系人或GroupMe关系创建s,并在任何时候提供他们的关系详细信息(因此我们可以显示本地联系人是GroupMe用户等 - 如屏幕截图中的Aaron G.)
我们也使用a NSFetchedResultsController,因此如果我们的后台操作找到任何新的联系人/关系,我们可以在UI中反映更新.
唯一的其他提示是确保您的获取请求预取所有关系,因此当您滚动以填充错误时,加载关系原因不会访问核心数据.
是的,虽然保持你的核心数据与用户的地址簿的同步比愚蠢更乏味,但它是值得的,所以你可以轻松访问它,并查询需要了解所有爵士乐的查询.
| 归档时间: |
|
| 查看次数: |
7904 次 |
| 最近记录: |