• UIPickerView的使用(二)


    复制代码
    //UIPickerViewDataSource中定义的方法,该方法的返回值决定该控件包含的列数
    - (NSInteger)numberOfComponentsInPickerView:(UIPickerView*)pickerView
    {
        return 2; // 返回2表明该控件只包含2列
    }
    
    //UIPickerViewDataSource中定义的方法,该方法的返回值决定该控件指定列包含多少个列表项
    - (NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component
    {
        // 如果该控件只包含一列,因此无须理会列序号参数component
        // 该方法返回teams.count,表明teams包含多少个元素,该控件就包含多少行
        if (component == 0) {
            return _areas.count;
        }
        else
            return _teams.count;
        
    }
    
    
    // UIPickerViewDelegate中定义的方法,该方法返回的NSString将作为UIPickerView中指定列和列表项的标题文本
    - (NSString *)pickerView:(UIPickerView *)pickerView
                 titleForRow:(NSInteger)row forComponent:(NSInteger)component
    {
        // 由于该控件只包含一列,因此无须理会列序号参数component
        // 该方法根据row参数返回teams中的元素,row参数代表列表项的编号,
        // 因此该方法表示第几个列表项,就使用teams中的第几个元素
        if (component == 0) {
            return [_areas objectAtIndex:row];
        }
        return [_teams objectAtIndex:row];
    }
    
    
    // 当用户选中UIPickerViewDataSource中指定列和列表项时激发该方法
    - (void)pickerView:(UIPickerView *)pickerView didSelectRow:
    (NSInteger)row inComponent:(NSInteger)component
    {
        
        NSArray *tmp = component == 0 ? _areas: _teams;
        NSString *tip = component == 0 ? @"区域":@"球队";
        // 使用一个UIAlertView来显示用户选中的列表项
        UIAlertView* alert = [[UIAlertView alloc]
                              initWithTitle:@"提示"
                              message:[NSString stringWithFormat:@"你选中的%@是:%@"
                                       , tip ,[ tmp objectAtIndex:row]]
                              delegate:nil
                              cancelButtonTitle:@"确定"
                              otherButtonTitles:nil];
        [alert show];
    }
    
    // UIPickerViewDelegate中定义的方法,该方法返回的NSString将作为
    // UIPickerView中指定列的宽度
    -(CGFloat)pickerView:(UIPickerView *)pickerView
       widthForComponent:(NSInteger)component
    {
        // 如果是第一列,宽度为90
        if(component == 0) {
            return 90;
        }
        return 210; // 如果是其他列(只有第二列),宽度为210
    }
    复制代码
  • 相关阅读:
    10 个超酷的加载中的 Gif 动画
    国内CDN公共库
    http://www.cnbeta.com/articles/306769.htm
    玩转WIN7的MKLINK
    盘点国内网站常用的一些 CDN 公共库加速服务
    15 个很棒的 Bootstrap UI 界面编辑器
    2014 年 20 款最好的 CSS 工具
    Web 开发中 20 个很有用的 CSS 库
    20+ 个很有用的 jQuery 的 Google 地图插件
    12 个 Web 设计师必备的 Bootstrap 工具
  • 原文地址:https://www.cnblogs.com/zhangyubao/p/6995069.html
Copyright © 2020-2023  润新知