iOS. Приемы программирования - страница 33
>if ([paramSender isEqual: self.mySegmentedControl]){
>NSInteger selectedSegmentIndex = [paramSender selectedSegmentIndex];
>NSString *selectedSegmentText =
>[paramSender titleForSegmentAtIndex: selectedSegmentIndex];
>NSLog(@"Segment %ld with %@ text is selected",
>(long)selectedSegmentIndex,
>selectedSegmentText);
>}
>}
>– (void)viewDidLoad{
>[super viewDidLoad];
>NSArray *segments = [[NSArray alloc] initWithObjects:
>@"iPhone",
>@"iPad",
>@"iPod",
>@"iMac", nil];
>self.mySegmentedControl = [[UISegmentedControl alloc]
>initWithItems: segments];
>self.mySegmentedControl.center = self.view.center;
>[self.view addSubview: self.mySegmentedControl];
>[self.mySegmentedControl addTarget: self
>action:@selector(segmentChanged:)
>forControlEvents: UIControlEventValueChanged];
>}
Если пользователь начинает выбирать слева и выбирает каждый параметр (см. рис. 1.22) до правого края, на консоль будет выведен следующий текст:
>Segment 0 with iPhone text is selected
>Segment 1 with iPad text is selected
>Segment 2 with iPod text is selected
>Segment 3 with iMac text is selected
Как видите, мы использовали метод selectedSegmentIndex сегментированного элемента управления, чтобы найти индекс варианта, выбранного в настоящий момент. Если ни один из элементов не выбран, метод возвращает значение –1. Кроме того, мы использовали метод titleForSegmentAtIndex:. Просто передаем этому методу индекс параметра, выбранного в сегментированном элементе управления, а сегментированный элемент управления возвратит текст, соответствующий этому параметру. Ведь просто, правда?
Как вы, вероятно, заметили, как только пользователь отмечает один из параметров в сегментированном элементе управления, этот параметр выбирается и остается выбранным, как показано на рис. 1.23. Если вы хотите, чтобы пользователь выбрал параметр, но кнопка этого параметра не оставалась нажатой, а возвращалась к исходной форме (так сказать, «отщелкивалась обратно», как и обычная кнопка), то нужно задать для свойства momentary сегментированного элемента управления значение YES:
>self.mySegmentedControl.momentary = YES;
Одна из самых приятных особенностей сегментированных элементов управления заключается в том, что они могут содержать не только текст, но и изображения. Для этого нужно просто использовать метод-инициализатор initWithObjects: класса UISegmentedControl и передать с этим методом те строки и изображения, которые будут применяться при реализации соответствующего пользовательского интерфейса:
>– (void)viewDidLoad{
>[super viewDidLoad];
>NSArray *segments = [[NSArray alloc] initWithObjects:
>@"iPhone",
>[UIImage imageNamed:@"iPad"],
>@"iPod",
>@"iMac",
>];
>self.mySegmentedControl = [[UISegmentedControl alloc]
>initWithItems: segments];
>CGRect segmentedFrame = self.mySegmentedControl.frame;
>segmentedFrame.size.height = 128.0f;
>segmentedFrame.size.width = 300.0f;
>self.mySegmentedControl.frame = segmentedFrame;
>self.mySegmentedControl.center = self.view.center;
>[self.view addSubview: self.mySegmentedControl];
>}
В данном примере файл iPad.png – это просто миниатюрное изображение «айпада», добавленное в наш проект.
В iOS 7 Apple отказалась от использования свойства segmentedControlStyle класса UISegmentedControl, поэтому теперь сегментированные элементы управления имеют всего один стиль, задаваемый по умолчанию. Мы больше не можем изменять этот стиль.
1.9. Представление видов и управление ими с помощью UIViewController