Я пытаюсь отобразить один UIPickerView в моем приложении, и в зависимости от того, какая кнопка выбрана, UIPickView будет всплывать и заполняться соответствующими данными для выбранной кнопки.Не уверен, что это важно, но один UIPickerView имеет три столбца, а один - два.Я могу заставить их работать отлично, когда они разделены, но в ту минуту, когда я вкладываю их, если операторы ломаются.
В третий раз, когда я выбираю кнопку, которая запускает противоположный UIPickerView, он вылетает и даетошибка NSRangeException и то, что он пытается найти объект по индексу 2 в массиве [0 ... 1].Насколько я понимаю, программа думает, что в месте в массиве есть объект, который не существует.
Я попробовал метод [picker reloadAllComponents] и вызывал его каждый раз при нажатии кнопки, но, как указано выше, он работает только один раз, а затем завершается.Странно то, что если я выбрал кнопку, которую я нажал для второго набора кода, он работает отлично.Когда я выбираю кнопку, из-за которой UIPickerView должен изменить свой вид, происходит сбой.
Я действительно новичок в разработке для iOS и Objective C и надеюсь, что кто-то там знает, что я делаю неправильно.Я опубликую любой код, который вам нужен, и выложу пару примеров, чтобы понять, что происходит.
Вот один из методов кнопок, который устанавливает для int значение 2, а также вызывает метод для отображения средства выбора.
-(IBAction)linePopupPicker{
picker = 2;
[self pickerShow];
}
Этот код является другим методом, который в значительной степени совпадает с другим (я знаю, что я еще не реализовал UserDefaults во второй кнопке)
-(IBAction)namePicker{
field = 1;
picker = 1;
NSLog(@"The value of field is:%i", field);
NSUserDefaults *pickerViewSelectionDefaults = [NSUserDefaults standardUserDefaults];
[tipPicker selectRow:[pickerViewSelectionDefaults integerForKey:@"pickerViewSelectionKey"] inComponent:0 animated:NO];
[tipPicker selectRow:[pickerViewSelectionDefaults integerForKey:@"pickerViewNameColor"] inComponent:1 animated:NO];
[tipPicker selectRow:[pickerViewSelectionDefaults integerForKey:@"pickerViewNameFontSize"] inComponent:2 animated:NO];
[self pickerShow];
}
Это метод, который вызывает UIPickerView.У меня это так, что оно выходит на вид, а не статично.Я подумал, что это будет лучшее место для перезагрузки компонентов.
-(IBAction)pickerShow{
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:0.5];
CGAffineTransform transform = CGAffineTransformMakeTranslation(0, 240);
pickerView.transform = transform;
[self.view addSubview:pickerView];
[tipPicker reloadAllComponents];
[UIView commitAnimations];
}
Наконец, вот лишь пример кода, который используется в различных методах, которые необходимо вызывать для UIPickerView.
- (UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view {
if (picker ==2) {
switch (component)
{
case 0:
{
UILabel *lineColorLabel = [[[UILabel alloc] initWithFrame:CGRectMake(0, 0, 130, 44)] autorelease];
lineColorLabel.backgroundColor = [UIColor clearColor];
NSString *lineTempColor = [colorArray1 objectAtIndex:row];
//NSLog(@"The String Color Name:%@", tempColor);
UIColor *myColor1 = [UIColor performSelector:NSSelectorFromString(lineTempColor)];
lineColorLabel.backgroundColor = myColor1;
return lineColorLabel;
}
case 1:
{
UILabel *alphaLabel = [[[UILabel alloc] initWithFrame:CGRectMake(0, 0,40, 44)] autorelease];
alphaLabel.text = [alphaArray objectAtIndex:row];
alphaLabel.font = [UIFont systemFontOfSize:18];
alphaLabel.textAlignment = UITextAlignmentCenter;
alphaLabel.backgroundColor = [UIColor clearColor];
alphaLabel.shadowColor = [UIColor whiteColor];
return alphaLabel;
}
default:
break;
}
}
else if (picker == 1)
{
switch (component)
{
case 0:
{
UILabel *fontLabel = [[[UILabel alloc] initWithFrame:CGRectMake(0, 0, 130, 44)] autorelease];
fontLabel.backgroundColor = [UIColor clearColor];
fontLabel.shadowColor = [UIColor whiteColor];
fontLabel.text = [fontNames objectAtIndex:row];
NSString *font = [fontNames objectAtIndex:row];
fontLabel.font = [UIFont fontWithName:font size:18.0];
fontLabel.textAlignment = UITextAlignmentLeft;
return fontLabel;
}
case 1:
{
UILabel *colorLabel = [[[UILabel alloc] initWithFrame:CGRectMake(0, 0, 35, 44)] autorelease];
NSString *tempColor = [colorArray objectAtIndex:row];
//NSLog(@"The String Color Name:%@", tempColor);
UIColor *myColor = [UIColor performSelector:NSSelectorFromString(tempColor)];
colorLabel.backgroundColor = myColor;
return colorLabel;
}
case 2:
{
UILabel *sizeLabel = [[[UILabel alloc] initWithFrame:CGRectMake(0, 0,40, 44)] autorelease];
sizeLabel.text = [fontSizeArray objectAtIndex:row];
sizeLabel.font = [UIFont systemFontOfSize:18];
sizeLabel.textAlignment = UITextAlignmentCenter;
sizeLabel.backgroundColor = [UIColor clearColor];
sizeLabel.shadowColor = [UIColor whiteColor];
return sizeLabel;
}
default:
break;
}
}
return 0;
}
Вот методы данных:
- (NSInteger)numberOfComponentsInPickerView:(UIPickerView *)thePickerView {
if (picker == 2) {
return 2;
}else if (picker == 1) {
return 3;
}
//return 3;
}
- (NSInteger)pickerView:(UIPickerView *)thePickerView numberOfRowsInComponent:(NSInteger)component { // This method also needs to be used. This asks how many rows the UIPickerView will have.
if (picker == 2) {
if (component == 0) {
return [colorArray1 count];
}
return [alphaArray count];
}else if (picker == 1) {
if (component == 0) {
return [fontNames count];
}else if (component == 1) {
return [colorArray count];
}
return [fontSizeArray count];
}
}
Я надеюсь, что этот пост предоставит всю информацию, которая необходима, чтобы помочь мне исправить это.Я действительно ценю это и надеюсь, что мне просто не хватает чего-то действительно простого.Заранее спасибо.
Я действительно новичок в разработке под iOS и Objective C, так что эта проблема меня действительно озадачила.