Estou tendo um comportamento estranho com presentViewController:animated:completion
. O que estou fazendo é essencialmente um jogo de adivinhação.
Eu tenho um UIViewController
(frequencyViewController) contendo um UITableView
(frequencyTableView). Quando o usuário toca na linha em questionTableView que contém a resposta correta, uma visualização (correctViewController) deve ser instanciada e sua visualização deve deslizar para cima da parte inferior da tela, como uma visualização modal. Isso informa ao usuário que ele tem uma resposta correta e redefine o frequencyViewController atrás dele, pronto para a próxima pergunta. correctViewController é dispensado ao pressionar um botão para revelar a próxima pergunta.
Isso tudo funciona corretamente todas as vezes, e a visualização do corretoViewController aparece instantaneamente, desde que presentViewController:animated:completion
tenha animated:NO
.
Se eu definir animated:YES
, correctViewController é inicializado e faz chamadas para viewDidLoad
. No entanto viewWillAppear
, viewDidAppear
e o bloco de conclusão de presentViewController:animated:completion
não são chamados. O aplicativo fica lá, ainda mostrando o frequencyViewController, até que eu faça um segundo toque. Agora, viewWillAppear, viewDidAppear e o bloco de conclusão são chamados.
Investiguei um pouco mais, e não é apenas outro toque que fará com que continue. Parece que se eu inclinar ou sacudir meu iPhone, isso também pode fazer com que ele acione o viewWillLoad etc. É como se ele estivesse esperando por qualquer outra entrada do usuário antes de prosseguir. Isso acontece em um iPhone real e no simulador, o que eu provei enviando o comando shake para o simulador.
Estou realmente sem saber o que fazer sobre isso ... Eu realmente aprecio qualquer ajuda que alguém possa fornecer.
obrigado
Aqui está meu código. É bem simples ...
Este é o código em questionViewController que atua como delegado para questionTableView
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
if (indexPath.row != [self.frequencyModel currentFrequencyIndex])
{
// If guess was wrong, then mark the selection as incorrect
NSLog(@"Incorrect Guess: %@", [self.frequencyModel frequencyLabelAtIndex:(int)indexPath.row]);
UITableViewCell *cell = [self.frequencyTableView cellForRowAtIndexPath:indexPath];
[cell setBackgroundColor:[UIColor colorWithRed:240/255.0f green:110/255.0f blue:103/255.0f alpha:1.0f]];
}
else
{
// If guess was correct, show correct view
NSLog(@"Correct Guess: %@", [self.frequencyModel frequencyLabelAtIndex:(int)indexPath.row]);
self.correctViewController = [[HFBCorrectViewController alloc] init];
self.correctViewController.delegate = self;
[self presentViewController:self.correctViewController animated:YES completion:^(void){
NSLog(@"Completed Presenting correctViewController");
[self setUpViewForNextQuestion];
}];
}
}
Este é todo o correctViewController
@implementation HFBCorrectViewController
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self)
{
// Custom initialization
NSLog(@"[HFBCorrectViewController initWithNibName:bundle:]");
}
return self;
}
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view from its nib.
NSLog(@"[HFBCorrectViewController viewDidLoad]");
}
- (void)viewDidAppear:(BOOL)animated
{
[super viewDidAppear:animated];
NSLog(@"[HFBCorrectViewController viewDidAppear]");
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
- (IBAction)close:(id)sender
{
NSLog(@"[HFBCorrectViewController close:sender:]");
[self.delegate didDismissCorrectViewController];
}
@end
Editar:
Eu encontrei esta pergunta antes: UITableView e presentViewController levam 2 cliques para exibir
E se eu mudar meu didSelectRow
código para isso, ele funciona muito bem com animação ... Mas é confuso e não faz sentido por que não funciona em primeiro lugar. Então eu não considero isso uma resposta ...
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
if (indexPath.row != [self.frequencyModel currentFrequencyIndex])
{
// If guess was wrong, then mark the selection as incorrect
NSLog(@"Incorrect Guess: %@", [self.frequencyModel frequencyLabelAtIndex:(int)indexPath.row]);
UITableViewCell *cell = [self.frequencyTableView cellForRowAtIndexPath:indexPath];
[cell setBackgroundColor:[UIColor colorWithRed:240/255.0f green:110/255.0f blue:103/255.0f alpha:1.0f]];
// [cell setAccessoryType:(UITableViewCellAccessoryType)]
}
else
{
// If guess was correct, show correct view
NSLog(@"Correct Guess: %@", [self.frequencyModel frequencyLabelAtIndex:(int)indexPath.row]);
////////////////////////////
// BELOW HERE ARE THE CHANGES
[self performSelector:@selector(showCorrectViewController:) withObject:nil afterDelay:0];
}
}
-(void)showCorrectViewController:(id)sender
{
self.correctViewController = [[HFBCorrectViewController alloc] init];
self.correctViewController.delegate = self;
self.correctViewController.modalTransitionStyle = UIModalTransitionStyleCrossDissolve;
[self presentViewController:self.correctViewController animated:YES completion:^(void){
NSLog(@"Completed Presenting correctViewController");
[self setUpViewForNextQuestion];
}];
}
presentViewController:
deve ser acionada começa com um grande atraso. Este parece ser um bug no iOS 7 e também é discutido no Apple Dev Forums.