DismissModalView не работает - PullRequest
       22

DismissModalView не работает

0 голосов
/ 10 декабря 2011

Я немного потянул за это волосы.Я создаю очень простое приложение, оно просто загружает 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

Ответы [ 2 ]

0 голосов
/ 17 декабря 2011

Единственный способ устранить эту ошибку - это синхронно загрузить данные, вставить и загрузить представление загрузки в стек навигации.Не идеально, но это работает.

0 голосов
/ 10 декабря 2011

В моем понимании ... ваше решение довольно сложное ... не было бы лучше, если бы класс MainTableViewController был тем, кто загружает каналы ... для ModalView он будет просто действовать как ActivityIndicator и удаляться после загрузки ..так что внутри вашего MainTableViewController loadview:

- (void)loadView
{
  NSString* urlString = FEED_URL;
  NSURL* url = [NSURL URLWithString:urlString];

  ASIHTTPRequest* request = [ASIHTTPRequest requestWithURL:url];
  [request startAsynchronous];
  //after starting the request show immediately the modalview
  modalView = [[ModalViewController alloc]init];
  [self presentModalViewController:modalView animated:NO];

  [request setCompletionBlock:^{
    // Use when fetching text data
    NSString *responseString = [request responseString];
    //then when it is complete dissmiss the modal
    [modalView dismissModalViewControllerAnimated:NO];

    // 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];
  }];


}

я не использовал блоки в своих проектах, но я думаю, что он будет работать так же .. также я использую простой UIActivityIndicatorView (большой) в качестве подпредставлений, а не modalViews ... к сожалению яне могу проверить код здесь сейчас .. но я могу проверить это позже, хотя

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...