Ho difficoltà ad aggiornare l'interfaccia utente utilizzando performSelectorOnMainThread. Ecco la mia situazione. Nel mio viewDidLoad ho impostato un indicatore di attività e un'etichetta. Quindi chiamo un selettore per recuperare alcuni dati da un server. Quindi chiamo un selettore per aggiornare l'interfaccia utente dopo un ritardo. Ecco il codice: controlliObiettivo C: problemi durante l'aggiornamento dell'interfaccia utente sul thread principale
- (void)viewDidLoad
{
[super viewDidLoad];
self.reloadSchools = [[UIAlertView alloc] init];
self.reloadSchools.message = @"There was an error loading the schools. Please try again.";
self.reloadSchools.title = @"We're Sorry";
self.schoolPickerLabel = [[UILabel alloc]init];
self.schoolPicker = [[UIPickerView alloc] init];
self.schoolPicker.delegate = self;
self.schoolPicker.dataSource = self;
self.server = [[Server alloc]init];
schoolList = NO;
_activityIndicator = [[UIActivityIndicatorView alloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
[self.view addSubview:_activityIndicator];
[self.view bringSubviewToFront:_activityIndicator];
[_activityIndicator startAnimating];
[NSThread detachNewThreadSelector: @selector(getSchoolList) toTarget: self withObject: nil];
[self performSelector:@selector(updateUI) withObject:nil afterDelay:20.0];
}
Il selettore updateUI per vedere se i dati sono stati recuperati e chiede un selettore sul thread principale per aggiornare l'interfaccia utente di conseguenza. Ecco il codice per queste parti:
-(void)updateUI
{
self.schools = [_server returnData];
if(!(self.schools == nil)) {
[self performSelectorOnMainThread:@selector(fillPickerView) withObject:nil waitUntilDone:YES];
}
else {
[self performSelectorOnMainThread:@selector(showError) withObject:nil waitUntilDone:YES];
}
}
-(void)showError {
NSLog(@"show error");
[_activityIndicator stopAnimating];
[self.reloadSchools show];
}
-(void)fillPickerView {
NSLog(@"fill picker view");
schoolList = YES;
NSString *schoolString = [[NSString alloc] initWithData:self.schools encoding:NSUTF8StringEncoding];
self.schoolPickerLabel.text = @"Please select your school:";
self.shoolArray = [[schoolString componentsSeparatedByString:@"#"] mutableCopy];
[self.schoolPicker reloadAllComponents];
[_activityIndicator stopAnimating];
}
Quando il selettore fillPickerView è chiamato indicatore di attività continua a girare, il testo dell'etichetta non cambia, e la vista selettore non ricarica suo contenuto. Qualcuno può spiegarmi perché il metodo che sto usando non sta funzionando per aggiornare il mio ui sul thread principale?
è possibile usa [GCD] (http://developer.apple.com/library/ios/#documentation/Performance/Reference/GCD_libdispatch_Ref/Reference/reference.html) per inviare i tuoi dati sull'altro thread e aggiornare l'interfaccia utente nel thread principale, è meglio dell'uso di NSThread. – johnMa