Кнопка UialertView Нажмите, вызывая сбой, когда все остальные работают нормально

StackOverflow https://stackoverflow.com/questions/2376668

Вопрос

У меня есть AlertView, который отлично отображает. В моем заголовке я включил UialertViewDelegate, но по какой-то причине всякий раз, когда я нажимаю кнопку на оповещении, мое приложение сбивается с вредным избытком, говоря, что нераспределенный селектор был отправлен.

Любые идеи будут полезны. У меня точно такой же код работает в других классах без проблем вообще.

Вот мой код:

    -(void)deletePatient
{
 NSLog(@"Delete");
 //Patient *patientInRow = (Patient *)[[self fetchedResultsController] objectAtIndexPath:cellAtIndexPath];
 NSMutableArray *visitsArray = [[NSMutableArray alloc] initWithArray:[patient.patientsVisits allObjects]];
 //cellAtIndexPath = indexPath;
 int visitsCount = [visitsArray count];
 NSLog(@"Visit count is %i", visitsCount);
 if (visitsCount !=0) 
 {
  //Display AlertView
  NSString *alertString = [NSString stringWithFormat:@"Would you like to delete %@'s data and all their visits and notes?", patient.nameGiven];
  UIAlertView *alert1 = [[UIAlertView alloc] initWithTitle:alertString message:nil delegate:self cancelButtonTitle:@"Yes" otherButtonTitles:@"No",nil];
  [alert1 show];
  [alert1 release];

 }
 else if (visitsCount ==0) 
 {
  //Do something else
 }

 [visitsArray release];

}

-(void)alertView:(UIAlertView*)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
 // the user clicked one of the OK/Cancel buttons
 if (buttonIndex == 0)
 {
  NSLog(@"Yes");

 }
 else
 {
  NSLog(@"No");
 }
}

Таким образом, самое лучшее, что я могу понять это, это связано с тем, что я называю методом удаления делитепатиента из моего подкласса UiableViewCell и проезжая вдоль объекта пациента, как я так. Вот код для передачи его вдоль

-(IBAction)deletePatient:(id)sender
{
    NSLog(@"Delete Patient:%@",patient.nameGiven);
    PatientListTableViewController *patientList = [[PatientListTableViewController alloc] init];
    patientList.patient = patient;
    UITableView *tableView = (UITableView *)[self superview];
    tableView.scrollEnabled = YES;
    [patientList deletePatient];
    menuView.center = CGPointMake(160,menuView.center.y);
    [patientList release];
}
Это было полезно?

Решение

Вы устанавливаете CatchenList Object в качестве делегата экземпляра UialertView, а затем выпустил его. Когда пользователь нажимает кнопку «Предупреждение», это называет [делегат ALERTVIEW: SEA CLICKEDBUTTONATINDEX: BOUTTINGINDEX], но делегат, пациентки уже выпущен и больше не существует. Переменная делегирование на данный момент содержать мусор, поэтому не удивит у него нет AlertView: clickbuttonatindex: селектор;

Просто выпустите объект PatimeList в Alert AlertView: clickbuttonatindex: Метод, или сделать пациента, создавая / выпуская при создании / выпуске внешнего класса или просто используйте свойство:

// В * .h Файл:

...
PatientListTableViewController *patientList;
...
@property(retain) PatientListTableViewController *patientList;
...

// в * .m Файл: @synthesize пациента;

...
self.patientList =  [[PatientListTableViewController alloc] init];

Другие советы

Все в порядке с указанным вами кодом. Если что-то фанк не происходит с предметом пациента где-то еще, я бы сказал, все выглядит хорошо здесь.

Попробуйте использовать UALIVIVE как AutoRelened объект, как это;

UIAlertView *alert1 = [[UIAlertView alloc] initWithTitle:alertString message:nil delegate:self cancelButtonTitle:@"Yes" otherButtonTitles:@"No",nil] autorelease];
[alert1 show];
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top