iOS-UIPickerView拾取器

来源:互联网 发布:竹笛联系软件 编辑:程序博客网 时间:2024/04/28 20:35

UIPickerView

UIPickerView是一个拾取器,UIPickerView和UIDatePicker是类似的控件,只不过UIDatePicker是日期控件,只能放日期,而UIPickerView可以放任何东西。它比UIDatePicker更加通用,它可以生成单列的选择器,也可生成多列的选择器,而且开发者完全可以自定义选择项的外观,因此用法非常灵活。UIPickerView直接继承了UIView,没有继承UIControl,因此,它不能像UIControl那样绑定事件处理方法,UIPickerView的事件处理由其委托对象完成。使用UIPickerView的对象应该遵守UIPickerViewDataSource,UIPickerViewDelegate。

 

常用属性和方法:

 

1、numberOfComponents:获取UIPickerView指定列中包含的列表项的数量。该属性是一个只读属性。 

2showsSelectionIndicator:该属性控制是否显示UIPickerView中的选中标记(以高亮背景作为选中标记)。 

3-numberOfRowsInComponent::获取UIPickerView包含的列数量。 

4- rowSizeForComponent::获取UIPickerView包含的指定列中列表项的大小。该方法返回一个CGSize对象。 

5- selectRow:inComponent:animated::该方法设置选中该UIPickerView中指定列的特定列表项。最后一个参数控制是否使用动画。

6- selectedRowInComponent::该方法返回该UIPickerView指定列中被选中的列表项。 

7- viewForRow:forComponent::该方法返回该UIPickerView指定列的列表项所使用的UIView控件。

 

注意:UIDatePicker控件只是负责该控件的通用行为,而该控件包含多少列,各列包含多少个列表项则由UIPickerViewDataSource对象负责。开发者必须为UIPickerView设置UIPickerViewDataSource对象,并实现如下两个方法。 

   

-numberOfComponentsInPickerView::该UIPickerView将通过该方法来判断应该包含多少列。   


-pickerView:numberOfRowsInComponent::该UIPickerView将通过该方法判断指定列应该包含多少个列表项 


如果程序需要控制UIPickerView中各列的宽度,以及各列中列表项的大小和外观,或程序需要为UIPickerView的选中事件提供响应,都需要为UIPickerView设置UIPickerViewDelegate委托对象,并根据需要实现该委托对象中的如下方法。   

 

- pickerView:rowHeightForComponent::该方法返回的CGFloat值将作为该UIPickerView控件中指定列中列表项的高度。   


-pickerView:widthForComponent::该方法返回的CGFloat值将作为该UIPickerView控件中指定列的宽度。   

 

- pickerView:titleForRow:forComponent::该方法返回的NSString值将作为该UIPickerView控件中指定列的列表项的文本标题。   


-pickerView:viewForRow:forComponent:reusingView::该方法返回的UIView控件将直接作为该UIPickerView控件中指定列的指定列表项。   

-pickerView:didSelectRow:inComponent::当用户单击选中该UIPickerView控件的指定列的指定列表项时将会激发该方法。 

 

PickerVIew的简单使用(先以单列选择器为例)


#import"ViewController.h"

#define SCREEN_BOUNDS [UIScreen mainScreen].bounds//屏幕尺寸

#define SCREEN_WIDTH CGRectGetWidth([UIScreenmainScreen].bounds)//屏幕宽

#define SCREEN_HEIGHT CGRectGetHeight([UIScreenmainScreen].bounds)//屏幕高

@interfaceViewController ()<UIPickerViewDataSource,UIPickerViewDelegate>//挂代理

{  UIPickerView *pickerView;//创建pickerVIew

  

   NSArray *dataArray;//创建数据源数组

} @end

@implementation ViewController

- (void)viewDidLoad {

    [superviewDidLoad];

    self.view.backgroundColor = [UIColorwhiteColor];

    dataArray = @[@"1",@"2",@"3",@"4",@"5",@"6"];

    pickerView = [[UIPickerView alloc]initWithFrame:CGRectMake(0,SCREEN_HEIGHT/2,SCREEN_WIDTH, SCREEN_HEIGHT/2)];

    [self.viewaddSubview:pickerView];

    pickerView.delegate = self;

    pickerView.dataSource = self;

}

#pragma mark 代理

//UIPickerViewDataSource中定义的方法,该方法的返回值决定该控件包含的列数

- (NSInteger)numberOfComponentsInPickerView:(UIPickerView*)pickerView{

    return 1;

    // 返回1表明该控件只包含1

}

    //UIPickerViewDataSource中定义的方法,该方法的返回值决定该控件指定列包含多少个列表项

- (NSInteger)pickerView:(UIPickerView*)pickerView numberOfRowsInComponent:(NSInteger)component{

    // 由于该控件只包含一列,因此无须理会列序号参数component

// 该方法返回teams.count,表明teams包含多少个元素,该控件就包含多少行

    return dataArray.count;

}

/* UIPickerViewDelegate中定义的方法  该方法返回的NSString将作为UIPickerView中指定列和列表项的标题文本  */

- (NSString *)pickerView:(UIPickerView*)pickerView  titleForRow:(NSInteger)rowforComponent:(NSInteger)component{

    // 由于该控件只包含一列,因此无须理会列序号参数component

    // 该方法根据row参数返回teams中的元素,row参数代表列表项的编号,

    // 因此该方法表示第几个列表项,就使用teams中的第几个元素

    return [dataArrayobjectAtIndex:row];

}

// 当用户选中UIPickerViewDataSource中指定列和列表项时激发该方法

- (void)pickerView:(UIPickerView*)pickerView didSelectRow:(NSInteger)rowinComponent:(NSInteger)component{

// 使用一个UIAlertView来显示用户选中的列表项

   NSString *alertString = [NSStringstringWithFormat:@"选中了第%ld,%ld",component,row];

    UIAlertController *alert = [UIAlertControlleralertControllerWithTitle:@"选中信息"message:alertStringpreferredStyle:UIAlertControllerStyleAlert];

    

    UIAlertAction *action = [UIAlertActionactionWithTitle:@"好的"style:UIAlertActionStyleDestructivehandler: ^(UIAlertAction *_Nonnullaction){

    

       }];

    [alert addAction:action];

    [selfpresentViewController:alert animated:YES completion:nil];

}

 

 

@end

0 0
原创粉丝点击