如何解决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秒后执行该操作吗?谢谢,在同时,请调用此方法。
应该通过用户界面(单击按钮)来关闭模态视图控制器,那么为什么要首先尝试呢?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。