A.需求
1.自定义一个UIView和xib,包含国家名和国旗显示
2.学习row的重用
B.实现步骤
1.准备plist文件和国旗图片
2.创建模型
1 //
2 // Flag.h
3 // CountriesSelection
4 //
5 // Created by hellovoidworld on 14/12/16.
6 // Copyright (c) 2014年 hellovoidworld. All rights reserved.
7 //
8
9 #import <Foundation/Foundation.h>
10
11 @interface Flag : NSObject
12
13 /** 国家名 */
14 @property(nonatomic, copy) NSString *name;
15
16 /** 国旗 */
17 @property(nonatomic, copy) NSString *icon;
18
19 - (instancetype) initWithDictionary:(NSDictionary *) dictionary;
20 + (instancetype) flagWithDictionary:(NSDictionary *) dictionary;
21
22 @end
1 //
2 // Flag.m
3 // CountriesSelection
4 //
5 // Created by hellovoidworld on 14/12/16.
6 // Copyright (c) 2014年 hellovoidworld. All rights reserved.
7 //
8
9 #import "Flag.h"
10
11 @implementation Flag
12
13 - (instancetype) initWithDictionary:(NSDictionary *) dictionary {
14 if (self = [super init]) {
15 [self setValuesForKeysWithDictionary:dictionary];
16 }
17
18 return self;
19 }
20
21 + (instancetype) flagWithDictionary:(NSDictionary *) dictionary {
22 return [[self alloc] initWithDictionary:dictionary];
23 }
24
25 @end
2.拖入PickerView, 准备主界面
3.实现dataSource和delegate方法
1 #pragma mark - dataSource function
2 - (NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView {
3 return 1;
4 }
5
6 - (NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component {
7 return self.countries.count;
8 }
9
10 #pragma mark - delegate function
11 // 使用返回UIView的row数据返回方法
12 - (UIView *) pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view {
13 //todo 创建自定义的view
14 }
4.创建自定义的UIView
5.设计自定row内容的xib,指定class
6.拖入控件到FlagView类,创建初始化方法和加载数据方法
1 //
2 // FlagView.h
3 // CountriesSelection
4 //
5 // Created by hellovoidworld on 14/12/16.
6 // Copyright (c) 2014年 hellovoidworld. All rights reserved.
7 //
8
9 #import <UIKit/UIKit.h>
10
11 @class Flag;
12 @interface FlagView : UIView
13
14 /** 国旗数据成员 */
15 @property(nonatomic, strong) Flag *flag;
16
17 /** 自定义构造方法 */
18 + (instancetype) flagViewWithPickerView:(UIPickerView *) pickerView;
19
20 /** 定义自己的高度 */
21 + (CGFloat) flagViewHeight;
22
23 @end
1 //
2 // FlagView.m
3 // CountriesSelection
4 //
5 // Created by hellovoidworld on 14/12/16.
6 // Copyright (c) 2014年 hellovoidworld. All rights reserved.
7 //
8
9 #import "FlagView.h"
10 #import "Flag.h"
11
12 @interface FlagView()
13
14 /** 国家名控件 */
15 @property (weak, nonatomic) IBOutlet UILabel *contryLabel;
16 /** 国旗控件 */
17 @property (weak, nonatomic) IBOutlet UIImageView *flagImage;
18
19 @end
20
21 @implementation FlagView
22
23 + (instancetype) flagViewWithPickerView:(UIPickerView *) pickerView {
24 return [[NSBundle mainBundle] loadNibNamed:@"FlagView" owner:nil options:nil].lastObject;
25 }
26
27 /** 加载数据 */
28 - (void) setFlag:(Flag *)flag {
29 _flag = flag;
30
31 // 1.国家名
32 self.contryLabel.text = flag.name;
33
34 // 2.国旗
35 self.flagImage.image = [UIImage imageNamed:flag.icon];
36 }
37
38 /** 定义自己的高度 */
39 + (CGFloat) flagViewHeight {
40 return 44;
41 }
42
43 @end
7.在控制器中加载解析数据
1 //
2 // ViewController.m
3 // CountriesSelection
4 //
5 // Created by hellovoidworld on 14/12/16.
6 // Copyright (c) 2014年 hellovoidworld. All rights reserved.
7 //
8
9 #import "ViewController.h"
10 #import "Flag.h"
11 #import "FlagView.h"
12
13 @interface ViewController () <UIPickerViewDataSource, UIPickerViewDelegate>
14
15 /** 国家选择器 */
16 @property (weak, nonatomic) IBOutlet UIPickerView *pickerView;
17
18 /** 国家数组 */
19 @property(nonatomic, strong) NSArray *countries;
20
21
22 @end
23
24 @implementation ViewController
25
26 - (void)viewDidLoad {
27 [super viewDidLoad];
28 // Do any additional setup after loading the view, typically from a nib.
29
30 // 设置dataSource
31 self.pickerView.dataSource = self;
32 // 设置delegate
33 self.pickerView.delegate = self;
34 }
35
36 - (void)didReceiveMemoryWarning {
37 [super didReceiveMemoryWarning];
38 // Dispose of any resources that can be recreated.
39 }
40
41 /** 加载数据 */
42 - (NSArray *) countries {
43 if (nil == _countries) {
44 NSArray * dictArray = [NSArray arrayWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"flags.plist" ofType:nil]];
45
46 NSMutableArray *mCountriesArray = [NSMutableArray array];
47 for (NSDictionary *dict in dictArray) {
48 Flag *flag = [Flag flagWithDictionary:dict];
49 [mCountriesArray addObject:flag];
50 }
51
52 _countries = mCountriesArray;
53 }
54
55 return _countries;
56 }
57
58 #pragma mark - dataSource function
59 - (NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView {
60 return 1;
61 }
62
63 - (NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component {
64 return self.countries.count;
65 }
66
67 #pragma mark - delegate function
68 // 使用返回UIView的row数据返回方法
69 - (UIView *) pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view {
70 FlagView *flagView = [FlagView flagViewWithPickerView:self.pickerView];
71 flagView.flag = self.countries[row];
72
73 return flagView;
74 }
75
76 /** 设置row的高度 */
77 - (CGFloat)pickerView:(UIPickerView *)pickerView rowHeightForComponent:(NSInteger)component {
78 return [FlagView flagViewHeight];
79 }
80
81 @end
out:
C.row的重用
PickerView没有像TableView一样提供缓存池的方法 dequeueReusableCellWithIdentifier
在PickerView的delegate的row数据加载方法中提供了reusingView,是iOS内核缓存的UIView
1 #pragma mark - delegate function
2 // 使用返回UIView的row数据返回方法
3 - (UIView *) pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view {
4
5 FlagView *flagView;
6 if (nil == view) {
7 flagView = [FlagView flagViewWithPickerView:self.pickerView];
8 } else {
9 NSLog(@"重用");
10 flagView = (FlagView *)view;
11 }
12
13 flagView.flag = self.countries[row];
14
15 NSLog(@"flagView - %p, view - %p", flagView, view);
16
17 return flagView;
18 }
==》但是在我的操作中,系统由始至终都没有传入缓存的UIView,每次都是使用了代码创建的FlagView
out:
2014-12-16 17:02:58.927 CountriesSelection[19352:1505008] flagView - 0x7ba7ee40, view - 0x0
2014-12-16 17:02:58.931 CountriesSelection[19352:1505008] flagView - 0x7b942300, view - 0x0
2014-12-16 17:02:58.936 CountriesSelection[19352:1505008] flagView - 0x79e44b80, view - 0x0
2014-12-16 17:02:58.937 CountriesSelection[19352:1505008] flagView - 0x79f64bc0, view - 0x0
2014-12-16 17:02:58.940 CountriesSelection[19352:1505008] flagView - 0x79f68e00, view - 0x0
2014-12-16 17:02:58.941 CountriesSelection[19352:1505008] flagView - 0x79f6a720, view - 0x0
2014-12-16 17:02:58.942 CountriesSelection[19352:1505008] flagView - 0x79f6bff0, view - 0x0
2014-12-16 17:02:58.943 CountriesSelection[19352:1505008] flagView - 0x79f6ff30, view - 0x0
2014-12-16 17:02:58.944 CountriesSelection[19352:1505008] flagView - 0x79f6e370, view - 0x0
2014-12-16 17:03:00.134 CountriesSelection[19352:1505008] flagView - 0x7b94a6c0, view - 0x0
2014-12-16 17:03:00.168 CountriesSelection[19352:1505008] flagView - 0x7b94b810, view - 0x0
2014-12-16 17:03:00.605 CountriesSelection[19352:1505008] flagView - 0x79f364c0, view - 0x0
2014-12-16 17:03:00.655 CountriesSelection[19352:1505008] flagView - 0x79f439e0, view - 0x0
2014-12-16 17:03:00.657 CountriesSelection[19352:1505008] flagView - 0x79f5a450, view - 0x0
2014-12-16 17:03:00.873 CountriesSelection[19352:1505008] flagView - 0x79f6cc60, view - 0x0
2014-12-16 17:03:01.477 CountriesSelection[19352:1505008] flagView - 0x7b94ce90, view - 0x0