iOS — Сборщики

Использование сборщиков

Средства выбора состоят из вращающегося прокручиваемого представления, которое используется для выбора значения из списка элементов.

Важные свойства

  • делегировать
  • источник данных

Важные методы

- (void)reloadAllComponents
- (void)reloadComponent:(NSInteger)component
- (NSInteger)selectedRowInComponent:(NSInteger)component
- (void)selectRow:(NSInteger)row inComponent:(NSInteger)component animated:(BOOL)animated

Обновите ViewController.h

Мы добавим экземпляры для текстового поля, окна выбора и массива. Мы будем использовать протоколы UITextFieldDelegate, UIPickerViewDataSource и UIPickerViewDelegate . ViewController.h выглядит следующим образом —

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController
   <UITextFieldDelegate, UIPickerViewDataSource, UIPickerViewDelegate> {
   UITextField *myTextField;
   UIPickerView *myPickerView;
   NSArray *pickerArray;
}
@end

Добавить собственный метод addPickerView

-(void)addPickerView {
   pickerArray = [[NSArray alloc]initWithObjects:@"Chess", 
   @"Cricket",@"Football",@"Tennis",@"Volleyball", nil];
   myTextField = [[UITextField alloc]initWithFrame:
   CGRectMake(10, 100, 300, 30)];
   myTextField.borderStyle = UITextBorderStyleRoundedRect;
   myTextField.textAlignment = UITextAlignmentCenter;
   myTextField.delegate = self;
   [self.view addSubview:myTextField];
   [myTextField setPlaceholder:@"Pick a Sport"];
   myPickerView = [[UIPickerView alloc]init];
   myPickerView.dataSource = self;
   myPickerView.delegate = self;
   myPickerView.showsSelectionIndicator = YES;
   UIBarButtonItem *doneButton = [[UIBarButtonItem alloc] 
   initWithTitle:@"Done" style:UIBarButtonItemStyleDone 
   target:self action:@selector(done:)];
   UIToolbar *toolBar = [[UIToolbar alloc]initWithFrame:
   CGRectMake(0, self.view.frame.size.height-
   myDatePicker.frame.size.height-50, 320, 50)];
   [toolBar setBarStyle:UIBarStyleBlackOpaque];
   NSArray *toolbarItems = [NSArray arrayWithObjects: 
   doneButton, nil];
   [toolBar setItems:toolbarItems];
   myTextField.inputView = myPickerView;
   myTextField.inputAccessoryView = toolBar;
}

Реализуйте делегатов, как показано ниже —

#pragma mark - Text field delegates

-(void)textFieldDidBeginEditing:(UITextField *)textField {
   if ([textField.text isEqualToString:@""]) {
      [self dateChanged:nil];
   }
}

#pragma mark - Picker View Data source
-(NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView {
   return 1;
}

-(NSInteger)pickerView:(UIPickerView *)pickerView 
   numberOfRowsInComponent:(NSInteger)component {
   return [pickerArray count];
}

#pragma mark- Picker View Delegate

-(void)pickerView:(UIPickerView *)pickerView didSelectRow:
   (NSInteger)row inComponent:(NSInteger)component {
   [myTextField setText:[pickerArray objectAtIndex:row]];
}

- (NSString *)pickerView:(UIPickerView *)pickerView titleForRow:
   (NSInteger)row forComponent:(NSInteger)component {
   return [pickerArray objectAtIndex:row];
}

Обновите viewDidLoad в ViewController.m следующим образом:

(void)viewDidLoad {
   [super viewDidLoad];
   [self addPickerView];
}

Вывод

Когда мы запустим приложение, мы получим следующий вывод —

Учебник iOS

При выборе текстового поля будет отображаться окно выбора, как показано ниже, где мы можем выбрать наш выбор —

Учебник iOS

Выберите поля, которые будут показаны. Прочие будут скрыты. Перктаскивайте мышкой для изменения порядка полей.
  • Изображение
  • SKU
  • Рейтинг
  • Цена
  • Запасы
  • Доступность
  • В корзину
  • Описание
  • Содержимое
  • Вес
  • Размеры
  • Дополнительная информация
  • Атрибуты
  • Custom attributes
  • Настраиваемые поля
Сравнить
Список желаний 0
Открыть страницу желаний Продолжить покупки