Я немного потянул за это волосы.Я создаю очень простое приложение, оно просто загружает RSS-канал и отображает его в UITableview, который находится внутри UINavigationController.Пока он загружает канал, я представляю модальное представление.
В моем модальном представлении я отображаю UIImageView и UIActivityIndicatorView, который настроен на вращение.Я использую ASIHTTRequest для асинхронного захвата канала, а затем использую либо блок завершения, чтобы получить строку ответа и остановить спиннер, либо блок сбоя, чтобы получить ошибку NSError и отобразить представление предупреждения.Все это прекрасно работает.
Затем я создал протокол, чтобы исключить модальное представление из табличного представления, которое вызывается внутри блока завершения.Но модальное представление никогда не отклоняется!Я попытался вставить его в контроллер навигации, но возникает точно такая же проблема.Я даже пытался установить для делегата модального представления значение nil, но все же не повезло.
Я проверил его без блоков, используя методы делегата ASIHTTPRequest, и это то же самое, и если я не представляю модальное представление,представление таблицы отображается нормально.
Есть идеи?Я пропустил все методы делегата и источника данных tableview, а также dealloc и все неиспользуемые функции.
@interface MainTableViewController ()
-(void)loadModalView;
@end
@implementation MainTableViewController
@synthesize tableView;
@synthesize modalView;
// Implement loadView to create a view hierarchy programmatically, without using a nib.
- (void)loadView
{
[super loadView];
tableView = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, self.view.bounds.size.width, self.view.bounds.size.height) style:UITableViewStylePlain];
tableView.delegate = self;
tableView.dataSource = self;
[self.view addSubview:tableView];
[self loadModalView];
}
-(void)loadModalView
{
modalView = [[ModalViewController alloc]init];
modalView.delegate = self;
[self presentModalViewController:modalView animated:NO];
}
//Modal View Delegate
-(void)downloadComplete
{
modalView.delegate = nil;
[self dismissModalViewControllerAnimated:NO];
}
@end
@interface ModalViewController ()
- (void)loadView
{
[super loadView];
backgroundImage = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, 320, 460)];
[self.view addSubview:backgroundImage];
spinner = [[UIActivityIndicatorView alloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
spinner.frame = CGRectMake(160, 240, spinner.bounds.size.width, spinner.bounds.size.height);
spinner.hidesWhenStopped = YES;
[self.view addSubview:spinner];
[spinner startAnimating];
NSString* urlString = FEED_URL;
NSURL* url = [NSURL URLWithString:urlString];
ASIHTTPRequest* request = [ASIHTTPRequest requestWithURL:url];
[request setCompletionBlock:^{
// Use when fetching text data
NSString *responseString = [request responseString];
[spinner stopAnimating];
[delegate downloadComplete];
// Use when fetching binary data
}];
[request setFailedBlock:^{
NSError *error = [request error];
UIAlertView* alert = [[UIAlertView alloc]initWithTitle:@"Error" message:error.description delegate:self cancelButtonTitle:@"Continute" otherButtonTitles: nil];
[alert show];
[alert release];
}];
[request startAsynchronous];
}
Matt