标签:
- (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated;
方法的时候,发现在不断点击一个按钮来调用这个方法,在点击返回调用- (UIViewController *)popViewControllerAnimated:(BOOL)animated;
这个方法,这是在快速多次点击返回不但没有返回,还多次向Navigition里面添加控制器。
额,黑苹果录制有点缺陷,自行脑补画面吧。
这是什么问题呢,代码不多,可以看看,那么问题究竟出在哪里呢?
//push
//触发点击事件
[btn addTarget:target action:action forControlEvents:UIControlEventTouchUpInside];
//接收按钮点击处理
- (void)btnClick:(UIButton *)btn{
[self.navigationController pushViewController:[[ETRecommendController alloc] init] animated:YES];
}
//pop
//触发点击时间
[backBtn addTarget:self action:@selector(pop)
//接受点击事件
- (void)pop{
[self popViewControllerAnimated:YES];
}
看看现在的分析
于是乎我发现在接受按钮push点击事件的方法调用多次,但是明明看到我还没返回根控制器啊,同时也看到我点击的返回按钮啊,突然间我发现我是这样调用push方法的[self.navigationController pushViewController:[[ETRecommendController alloc] init] animated:YES];
注意后面的animated:YES
Navigation的跳转带动画效果,而这个动画效果是通过CoreAnimation的专场动画来实现的,而动画的需要时间,而在RunLoop里面的NSDispalyLink与NStimer那么如果在一定时间内没有执行完任务会自动跳过,而现在会不会类似这样呢,毕竟是都是基于线程运行的,而线程的架构模式又是RunLoop,亦即是说执行动画需要时间,在这个时间里面没有执行完动画,那么RunLoop直接处理下一个Source
。
额...,如果是这样的话,那么直接把动画设为NO就行了吧,于是把YES换成NO,的确,一点问题也没有,问题这样似乎是解决了,请留意我上面说的一个细节。
在按钮的两端点才回出现这个bug,在中间点则一切正常
如果说在两端和中间点击的效果一样的话,这样动画的YES和NO就很有说服力了,但是现在明显不是。
于是乎现在又是这样一个状况
在我们点击过去的时候,push键(非返回键)动画效果的时候,变成了这样一个局势:中间的一个模块不能接收相应,而周围可以,也就是说,中间和周围不是同一块控件,毕竟根据响应者链条,寻找最合适的View,所以,如果能接收事件那他一定是同一块View,除非他不遵循响应者链条,而现在就是这个局势,一个控件居然不遵循响应者链条,好吧,这个猜想有点大胆,理由也比较勉强。
这里需要普及一下苹果的一些细节的知识,在我们点击iPhone键盘的时候,例如我点击了g,那么苹果会从他系统自带的猜词字典里面猜想我们下一个会按什么,这是可能是good,也可能是god,但是可以肯定的是o的触控范围一定比某一些字母的触控范围大,也就是说虽然我们看起来键盘一直没有变化,他的每个字母能接收事件的范围永远都在动态变化的,这也是苹果用户体验比较好的一个细节。
行了,有了上面的小提示,你应该想到我接下来要讲什么了吧,就是我们的返回按钮的接收事件的范围会被放大,当然这只是我的一个猜想,那么如果我的猜想成功的话,现在就是这个局势,中间一个push键的确push后不能点击,但是他的响应范围被放大了,所以就形成了中间点击正常,边框点击会调用push方法,这样猜想貌似合理,这种猜想与上面的那种猜想结合起来应该会比较合理,但是毕竟是猜想。
至于解决方案,很简单,我猜你也想到了,不过为什么会出现这个bug,这才是最重要的,至少求学态度没有错,解决方案:大体是:
- (BOOL)checkIsExit:(id)VC{
for (id classObj in self.childViewControllers) {
Class class = [classObj class];
if ([VC isKindOfClass:class]) {
return YES;
}
}
return NO;
}
Observable-Swift
,这个框架很好的利用了Swift的泛型,如果的OC,自行到github上寻找框架。标签:
原文地址:http://www.cnblogs.com/superYou/p/4675442.html