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都无法再次工作。
那么,这里发生了什么?我意识到,和其他人一样,我可以通过各种变通办法来实现我的目标,包括使用委托等。但是,我真的认为,遇到此问题的每个人都应该对问题和问题都有透彻的了解,这将是一件好事。针对这种情况的正确解决方案。顺便说一句,这种情况的一个用例是模态地呈现加载屏幕,其中用户没有与该屏幕的交互。它只是用来在阻止用户执行操作的同时提供信息。
没有找到相关结果
已邀请:
1 个回复
佩疵瓦