dismissModalViewControllerAnimated之谜

| 我已经看过许多关于此主题的文章,但是没有一篇让我对正在发生的事情有清晰的了解。 我已经设置了一个涉及两个UIViewControllers的小型测试:MainController和ModalController。 MainController上面有一个按钮,它使用以下简单代码显示模式视图控制器:
ModalController *myModal = [[ModalController alloc] init];
[self presentModalViewController:myModal animated:YES];
[myModal release];
现在,如果我立即从同一代码块中解散此模态控制器,则按照下一行:
[self dismissModalViewControllerAnimated: YES];
模态视图不会关闭。 遵循此站点上的一些建议后,我将
dismissModalViewControllerAnimated
调用放在一个单独的方法中,然后使用调用:
[self performSelector:@selector(delayedDismissal) withObject:nil 
  afterDelay:0.41];
这有效-至少如果我将延迟设为0.41或更大。 .40或更小,它不起作用。 在这一点上,我假设我在这里处理的是一个运行循环,由于缺乏更好的描述,该循环需要自我追赶。不幸的是,它不是很稳定。 因此,对于下一个测试,我不让delayDismissal做任何事情-它仅提供一个延迟-然后将dismissModalViewControllerAnimated调用重新插入到原始块中,这样我的代码现在看起来像这样:
ModalController *myModal = [[ModalController alloc] init];
[self presentModalViewController:myModal animated:YES];
[myModal release];
self performSelector:@selector(delayedDismissal) withObject:nil 
      afterDelay:0.41]; // to create the false delay
[self dismissModalViewControllerAnimated: YES];
...现在不管我使用了多长时间的延迟,dismissModalViewControllerAnimated都无法再次工作。 那么,这里发生了什么?我意识到,和其他人一样,我可以通过各种变通办法来实现我的目标,包括使用委托等。但是,我真的认为,遇到此问题的每个人都应该对问题和问题都有透彻的了解,这将是一件好事。针对这种情况的正确解决方案。顺便说一句,这种情况的一个用例是模态地呈现加载屏幕,其中用户没有与该屏幕的交互。它只是用来在阻止用户执行操作的同时提供信息。     
已邀请:
        该视图处于动画状态,因此,只要处于动画状态,调用dismiss将不起作用。 同样,在您尝试的第二件事中,您正在调用\“ delay \”,但是您实际上正在执行以下操作:\“好吧,这是一种可爱的方法,您可以在0.41秒后执行该操作吗?谢谢,在同时,请调用此方法。 应该通过用户界面(单击按钮)来关闭模态视图控制器,那么为什么要首先尝试呢?     

要回复问题请先登录注册