У меня возникли проблемы с обновлением интерфейса пользователя с помощью функции performSelectorOnMainThread. Вот моя ситуация. В моем представленииDidLoad я установил индикатор активности и метку. Затем я вызываю селектор для получения некоторых данных с сервера. Затем я вызываю селектор для обновления пользовательского интерфейса после задержки. Вот код:Objective C- Устранение неполадок UI в главной теме
- (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];
}
Селектор updateUI проверяет, были ли данные получены, и вызывает селектор на главном потоке, чтобы обновить интерфейс соответствующим образом. Вот код для этих частей:
-(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];
}
Когда fillPickerView селектора называется индикатор активности продолжает вращаться, текстовая метка не меняется, и вид выбора не перезагружать его содержание. Может кто-нибудь объяснить мне, почему метод, который я использую, не работает, чтобы обновить мой ui в основном потоке?
вы можете используйте [GCD] (http://developer.apple.com/library/ios/#documentation/Performance/Reference/GCD_libdispatch_Ref/Reference/reference.html) для отправки ваших данных в другой поток и обновления интерфейса в основном потоке, это лучше, чем использование NSThread. – johnMa