繁体   English   中英

单击UITextField时如何在UIPickerView中显示信息

[英]How to display information in UIPickerView when clicking on UITextField

我一直在寻找并尝试为此问题提供的所有代码示例,但是我似乎无法使其正常运行。 这是我第一次制作应用程序(除了完成教程之外),因此请原谅我提出“愚蠢”的问题。 我只是一个新手。

我正在尝试创建一个iOS应用来注册开始和结束时间,服务类型和客户。 用户点击UITextField时,会弹出UIPicker,显示信息。 我能够为开始时间和结束时间创建UIDatePicker,并为服务和客户创建一个空的UIPickerView。

我遇到的问题是我正在尝试将客户的名称和服务类型添加到每个UIPickerView中。 但是到目前为止没有成功。 我尝试通过添加数组来执行此操作,但是UIPickerView中没有任何显示。 在情节提要中,我为每个项目添加了4个标签和4个UITextField。

.h的代码如下所示:

@interface ViewController : UIViewController <UIPickerViewDataSource, UIPickerViewDelegate> {
    UIDatePicker *datePicker;
    UIDatePicker *datePicker2;
    NSArray *dienstArray;
    NSArray *klantArray;
}

@property (strong, nonatomic) IBOutlet NSArray *dienstArray;        //Service Array
@property (strong, nonatomic) IBOutlet NSArray *klantArray;         //Customer Array
@property (weak, nonatomic) IBOutlet UIPickerView *dienstPicker;    //Service PickerView
@property (weak, nonatomic) IBOutlet UIPickerView *klantPicker;     //Customer PickerView
@property (weak, nonatomic) IBOutlet UITextField *dienstTextField;  //Service TextField
@property (weak, nonatomic) IBOutlet UITextField *klantTextField;   //Customer TextField
@property (weak, nonatomic) IBOutlet UITextField *dateSelectionTextField;   //BeginDate TextField
@property (weak, nonatomic) IBOutlet UITextField *dateSelectionTextField2;  //EndDate TextField

@end

这是.m @interface ViewController()@end的代码

@implementation ViewController
@synthesize dienstPicker;
@synthesize klantPicker;
@synthesize klantArray;
@synthesize dienstArray;

- (void)viewDidLoad {
    [super viewDidLoad];


    //BeginDatumTijdPicker
    datePicker=[[UIDatePicker alloc]init];
    datePicker.datePickerMode=UIDatePickerModeDateAndTime;

    NSLocale *locale = [[NSLocale alloc] initWithLocaleIdentifier:@"NL"];       //Date notation 24hours
    [datePicker setLocale: locale];

    // Styling for the UIPickerView
    [self.dateSelectionTextField setInputView:datePicker];                              //shows the UIPickerView
    UIToolbar *toolBar=[[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 44)];
    [toolBar setTintColor:[UIColor grayColor]];
    UIBarButtonItem *doneBtn=[[UIBarButtonItem alloc]initWithTitle:@"Done" style:UIBarButtonItemStylePlain target:self action:@selector(ShowSelectedDate1)];    //When clicked "Done" the UIPickerView disappears.
    UIBarButtonItem *space=[[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil action:nil];
      [toolBar setItems:[NSArray arrayWithObjects:space,doneBtn, nil]];
        [self.dateSelectionTextField setInputAccessoryView:toolBar];

//EindDatumTijdPicker
// [Same as BeginDatumTijdPicker but different names]

        //DienstPicker

    dienstPicker =[[UIPickerView alloc] init];
    dienstArray = [[NSArray alloc] initWithObjects: @"test1", @"test2", @"test3", @".....", nil];
    self.dienstPicker.delegate = self;
    self.dienstPicker.dataSource = self;
    self.dienstPicker.showsSelectionIndicator = YES;

    // Styling for the UIPickerView
    [self.dienstTextField setInputView:dienstPicker];               //shows the UIPickerView
    UIToolbar *toolBar3 = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 44)];
    [toolBar3 setTintColor:[UIColor grayColor]];
    UIBarButtonItem *doneBtn3=[[UIBarButtonItem alloc]initWithTitle:@"Done" style:UIBarButtonItemStylePlain target:self action:@selector(ShowSelectedDienst)]; //When clicked "Done" the UIPickerView disappears.
    UIBarButtonItem *space3 = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil action:nil];
    [toolBar3 setItems:[NSArray arrayWithObjects:space3,doneBtn3,nil]];
    [self.dienstTextField setInputAccessoryView:toolBar3];


    //KlantPicker

    klantPicker =[[UIPickerView alloc] init];
    klantArray = [[NSArray alloc] initWithObjects: @"test1.1", @"test2.1", @"test3.1", @".....", nil];
    self.klantPicker.delegate= self;
    self.klantPicker.dataSource = self;
    self.klantPicker.showsSelectionIndicator = YES;

    // Styling for the UIPickerView
    [self.klantTextField setInputView:klantPicker];             //shows the UIPickerView
    UIToolbar *toolBar4 = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 44)];
    [toolBar4 setTintColor:[UIColor grayColor]];
    UIBarButtonItem *doneBtn4 =[[UIBarButtonItem alloc]initWithTitle:@"Done" style:UIBarButtonItemStylePlain target:self action:@selector(ShowSelectedKlant)]; //When clicked "Done" the UIPickerView disappears.
    UIBarButtonItem *space4 = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil action:nil];
    [toolBar4 setItems:[NSArray arrayWithObjects:space4,doneBtn4,nil]];
    [self.klantTextField setInputAccessoryView:toolBar4];

}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

//ShowSelectedService (When clicking the "Done" button, the UIPickerView disappears. )

-(void)ShowSelectedDienst{
    [self.dienstTextField resignFirstResponder];
}

//ShowSelectedClient (When clicking the "Done" button, the UIPickerView disappears. )

-(void)ShowSelectedKlant{
    [self.klantTextField resignFirstResponder];

}

// The code below
// works just fine.
//DatePicker Begin tijd
-(void)ShowSelectedDate1 {
    NSDateFormatter *formatter=[[NSDateFormatter alloc]init];
    [formatter setDateFormat:@"dd MMM HH:mm"];                  //formats date & time
    self.dateSelectionTextField.text=[NSString stringWithFormat:@"%@",[formatter stringFromDate:datePicker.date]];
    [self.dateSelectionTextField resignFirstResponder];
}

//!!DatePicker Eind tijd!!
//Same as DatePicker Begin Tijd.    
@end

我希望一切都清楚,有人可以帮助我。 这是应用程序的外观:

单击“服务”文本字段时,将弹出UIPickerView。

似乎在代码中没有地方设置UIPickerView的委托和数据源。 没有它们,选择器视图将不知道显示什么以及如何通知您用户已选择了某些内容。

请在这里查看: UIPickerViewDataSourceUIPickerViewDelegate ,如果有不清楚的地方或者在实现这些问题时遇到麻烦,请告诉我。


这是一个例子:

@interface ViewController () <UIPickerViewDelegate, UIPickerViewDataSource> //#1

@property (nonatomic, strong) UITextField *textField;
@property (nonatomic, strong) UIPickerView *pickerView;
@property (nonatomic, strong) NSArray *pickerNames;

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];

    self.pickerView = [[UIPickerView alloc] init];
    self.pickerView.delegate = self;     //#2
    self.pickerView.dataSource = self;   //#2

    self.textField = [[UITextField alloc] initWithFrame:CGRectMake(0, 100, CGRectGetWidth(self.view.frame), 50)];
    self.textField.borderStyle = UITextBorderStyleRoundedRect;
    self.textField.placeholder = @"What's your favourite programming language?";
    self.textField.inputView = self.pickerView;

    self.pickerNames = @[ @"Objective-C", @"Swift", @"Java", @"C", @"C++", @"Other"];

    [self.view addSubview:self.textField];
}

#pragma mark - UIPickerViewDataSource

// #3
-(NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView {
    if (pickerView == self.pickerView) {
        return 1;
    }

    return 0;
}

// #4
-(NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component {
    if (pickerView == self.pickerView) {
        return [self.pickerNames count];
    }

    return 0;
}

#pragma mark - UIPickerViewDelegate

// #5
-(NSString *)pickerView:(UIPickerView *)pickerView titleForRow:(NSInteger)row forComponent:(NSInteger)component {
    if (pickerView == self.pickerView) {
        return self.pickerNames[row];
    }

    return nil;
}

// #6
-(void)pickerView:(UIPickerView *)pickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component {
    if (pickerView == self.pickerView) {
        self.textField.text = self.pickerNames[row];
    }
}

@end

好的,这是有趣的部分:

  1. 在这里,我们声明我们将遵守UIPickerViewDelegateUIPickerViewDataSource协议。 协议从根本上讲就是一组方法标头。 当您声明要遵守协议时,您需要实现它们(至少是必需的)。

  2. 这很明显,我们告诉选择器我们将成为它的委托和数据源。 如果我们之前未声明符合协议,则编译器将在此处开始向我们提供错误。

    1. 将调用UIPickerViewDataSource此方法以知道应显示多少个组件。 例如,日期选择器通常具有3个组成部分(天,月,年)。

    2. 该方法想知道每个组件中有多少个元素。

    3. 该方法是您实际提供要显示给用户的文本的地方。 您还可以实现此方法的其他两个变体之一,以提供属性文本或完全自定义的视图。

    4. 当动画停止在新项目上时,将调用此方法。

在此示例中,不需要检查pickerView == self.pickerView 我已经添加了它们,以便您知道如何决定要为哪个选择器(似乎有4个)返回所需的信息。 理想情况下,这将需要进一步的重构,因为使委托/数据源杂乱无章不是最好的主意。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM