ios 构建含有多个滚轮的表格

有时用户需要从一份很长的列表中选择某个条目,或是需要同时从多份列表中分别做出选择。UIPickerView实例很适合这些情况下。UIPickerVIew对象制作出的表格提供了很多各自独立的滚轮。用户可以通过操作这些滚轮来做出选择

他们使用的独特的数据源协议和委托协议:

1、没有UIPickerViewController类。UIPickerView实例扮演其他视图的子视图。在应用程序里,它们并不打算成为视图的中心焦点。开发者可以把UIPickerView实例放在另一个视图里面。

2、UIPickerView采用数字而非对象来表示其中的滚轮。UIPickerView里的组件是用数字来编号的,而不与NSIndexPath实力相对应。这个类不像UITableVIew那样严整。

在实现数据源协议时,开发者可以提供字符串,也可以提供视图。这两种方式UIPickerView都能处理。

1、创建UIPickerView

创建选取器的时候,别忘了设置delegate与dataSource。如果不这样做,那么就无法向视图里添加数据、无法定义其特性,也无法响应用户所做的选择。主视图控制器应该实现UIPickerViewDelegate与UIPickerViewDataSource协议

2、数据源方法与委托方法

为了使UIPickerView具备最基本的功能,需要实现三个关键的数据源方法:

1、numberOfComponentsInPickerView:——该方法返回视图里的列数,其返回值是个整数。

2、pickerVIew:numberOfRowsInComponent:——该方法返回每个滚轮所具备的行数,其返回值是个整数。滚轮的行数不一定都要相同。其中一个滚轮可以有很多行,而另外一个滚轮则可以只有几行。

3、pickerVIew:titleForRow:forComponent:或pickerView:viewForRow:forComponent:reusingView:——这两个方法可以为滚轮中的某一行指定文本或视图,以便用作该行的标签。

3、主要代码

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    self.view.backgroundColor = [UIColor whiteColor];
    UIPickerView *picker = [[UIPickerView alloc] initWithFrame:CGRectMake(0, 100, self.view.frame.size.width, 200)];
    [self.view addSubview:picker];
    picker.delegate = self;
    picker.dataSource = self;
    picker.showsSelectionIndicator = YES;
    
    [picker selectRow:5000 + (rand() % 4) inComponent:0 animated:YES];
    [picker selectRow:5000 + (rand() % 4) inComponent:1 animated:YES];
    [picker selectRow:5000 + (rand() % 4) inComponent:2 animated:YES];
}

- (NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView
{
    return 3;
}

- (NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component
{
    return 1000000;
}

- (CGFloat)pickerView:(UIPickerView *)pickerView rowHeightForComponent:(NSInteger)component
{
    return 120;
}

- (UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view
{
    NSArray *names = @[@"club",@"diamond",@"heart",@"spade"];
    UILabel *label = (UILabel *)view;
    label.text = names[row%4];
    if (!label) {
        label = [[UILabel alloc] init];
        label.text = names[row%4];
    }
    return label;
}

- (void)pickerView:(UIPickerView *)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component
{
    NSArray *names = @[@"C",@"D",@"H",@"S"];
    self.title = [NSString stringWithFormat:@"%@ %@ %@",names[[pickerView selectedRowInComponent:0] % 4],names[[pickerView selectedRowInComponent:1] % 4],names[[pickerView selectedRowInComponent:2] % 4]];
}
在这里将每个滚轮的总行数定为一百万,之所以这么大就是为了模拟出真实的圆柱形滚轮。一般来说,UIPickerView里面的滚轮都有其实元素和终止元素,滚轮到了最后一个元素之后,就不能再继续滚动了。于是,我们会想:如果程序里的滚轮和真实的圆柱形滚轮一样,那么在到达了最后一项之后,接下来应该又出现第一项才对。为了模拟这种效果,就将行数设成了一个非常大的值,使得用户不太可能滚动到末端。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值