本地化下按首字母分组排序的神器——UILocalizedIndexedCollation
来源:互联网 发布:ubuntu gnome dock 编辑:程序博客网 时间:2024/04/30 17:08
http://www.cnblogs.com/ningxu-ios/p/4183542.html?utm_source=tuicool&utm_medium=referral
最近在整一个很简单的通讯录相关的项目,通讯录当然就少不了按首字母或者汉字拼音首字母分组排序索引。因为按照我一贯的的做法,都是想要做成更通用的、支持本地化的,所以这就纠结了,世界各地的语言啊我去,我顶多也就认识中文和英语,这就不能用以前的那些比如把汉字转成拼音再排序的方法了,效率不高不说,对其他国家的本地化更是行不通。一个偶然的机会,我才发现SDK里已经提供了一个实现此功能的神器——UILocalizedIndexedCollation。
首先提一下,UILocalizedIndexedCollation的分组排序是建立在对对象的操作上的。下边我会举个栗子讲解一下。首先已知有一个Person类:
1 @interface Person : NSObject2 @property(nonatomic, strong) NSString *name;3 @end
然后初始化一些对象存入一个数组(注:为了后续说明方便,我直接拿name的值来表示Person类的对象,实际编码中是要用对象!如下列<林丹>表示p.name = @"林丹"的Person类对象p)
1 NSArray *srcArray = @[<林荣>, <林丹>, <周董>, <周树人>, <周杰伦>, <阿华>];
先将UILocalizedIndexedCollation初始化,
1 UILocalizedIndexedCollation *collation = [UILocalizedIndexedCollation currentCollation];
可以看出来这是一个单例,它会根据不同国家的语言初始化出不同的结果。如中文和英文的得到的就是A~Z和#,日语的就是A~Z,あ, か, さ, た, な, は, ま, や, ら, わ和#。下边我就以最熟悉的中文环境为例,直接上代码了,注意看注释部分的讲解
1 //得出collation索引的数量,这里是27个(26个字母和1个#) 2 NSInteger sectionTitlesCount = [[collation sectionTitles] count]; 3 4 //初始化一个数组newSectionsArray用来存放最终的数据,我们最终要得到的数据模型应该形如@[@[以A开头的数据数组], @[以B开头的数据数组], @[以C开头的数据数组], ... @[以#(其它)开头的数据数组]] 5 6 NSMutableArray *newSectionsArray = [[NSMutableArray alloc] initWithCapacity:sectionTitlesCount]; 7 8 //初始化27个空数组加入newSectionsArray 9 for (NSInteger index = 0; index < sectionTitlesCount; index++) {10 NSMutableArray *array = [[NSMutableArray alloc] init];11 [newSectionsArray addObject:array];12 }13 14 //将每个人按name分到某个section下15 16 for (Person *p in srcArray) {17 //获取name属性的值所在的位置,比如"林丹",首字母是L,在A~Z中排第11(第一位是0),sectionNumber就为1118 NSInteger sectionNumber = [collation sectionForObject:p collationStringSelector:@selector(name)];19 //把name为“林丹”的p加入newSectionsArray中的第11个数组中去20 NSMutableArray *sectionNames = newSectionsArray[sectionNumber];21 [sectionNames addObject:p]; 22 }23 24 //对每个section中的数组按照name属性排序25 for (NSIntger index = 0; index < sectionTitlesCount; index++) {26 NSMutableArray *personArrayForSection = newSectionsArray[index];27 NSArray *sortedPersonArrayForSection = [collation sortedArrayFromArray:personArrayForSection collationStringSelector:@selector(name)];28 newSectionsArray[index] = sortedPersonArrayForSection;29 }
最终把newSectionsArray应该形如@[@[<阿华>], @[], @[], ... @[<林丹>, <林荣>], ... @[<周董>, <周杰伦>, <周树人>], @[]]
后续工作就是把这个数组作为数据源与UITableView通过tableView的Delegate关联起来了,部分如下,在此不再赘述
1 - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section { 2 return [collation sectionTitles][section]; 3 } 4 5 - (NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView { 6 return [collation sectionIndexTitles]; 7 } 8 9 - (NSInteger)tableView:(UITableView *)tableView sectionForSectionIndexTitle:(NSString *)title atIndex:(NSInteger)index {10 return [collation sectionForSectionIndexTitleAtIndex:index];11 }
不过呢,使用这个UILocalizedIndexedCollation有一个缺点就是不能区分姓氏中的多音字,比如“曾”会被分到"C"组去,不知道大家有没有基于此的好方法在下边回复。下边是苹果官方示例,其中第3个是关于UILocalizedIndexedCollation的,可以下载下来学习一下http://developer.apple.com/library/ios/samplecode/TableViewSuite/Introduction/Intro.html
- 本地化下按首字母分组排序的神器——UILocalizedIndexedCollation
- 本地化下按首字母分组排序的神器——UILocalizedIndexedCollation
- 本地化下按首字母分组排序的神器——UILocalizedIndexedCollation
- 本地化下按首字母分组排序的神器——UILocalizedIndexedCollation
- 本地化下按首字母分组排序的神器——UILocalizedIndexedCollation
- 本地化下按首字母分组排序的神器——UILocalizedIndexedCollation
- iOS UILocalizedIndexedCollation排序神器
- 通讯录分组排序(UILocalizedIndexedCollation)
- iOS开发------通讯录分组排序(UILocalizedIndexedCollation)
- UILocalizedIndexedCollation ios首字母排列
- 用系同自带的排序神器对通讯录按字母分组排序
- java 中文首字母分组,排序
- js按照首字母分组排序
- 关于城市列表按首字母排序、分组及查找的一个解决方案(mysql端)java
- 005_015 Python 人名按字母排序,首字母分组
- 排序——使用Collator进行本地化语言的排序
- java中英文获取首字母之后分组排序
- 根据字符串首字母分组并内部排序
- 需求 - 5 - 悬浮框 - 3
- javascript的window.ActiveXObject对象,区别浏览器的方法
- Win8下Android SDK的安装与环境变量配置
- LINUX 下安装 jdk 问题(please use alien to install rpm packages on Debian )
- 深入浅出 React Native:使用 JavaScript 构建原生应用
- 本地化下按首字母分组排序的神器——UILocalizedIndexedCollation
- 通用正则匹配
- AR资料
- POJ 3050 Hopscotch
- MySQL 5.6.14 win32 zip版安装
- OpenCV中CV_IS_MAT_CONT(src->type & dst->type) 的含义!
- 【leetcode】209. Minimum Size Subarray Sum
- Prime Ring Problem
- solr5.4的安装配置