【iOS开发-56】案例BUG:按钮的enabled、控件的userInteractionEnabled以及两种提示框UIAlert和UIActionSheet
接上述案例找BUG:【iOS开发-51】案例学习:动画新写法、删除子视图、视图顺序、延迟方法、按钮多功能用法及icon图标和启动页设置
(1)BUG:答案满了就不能再点击option按钮,答案没满就能点。
在optionClick方法的if(full)中设置,即判断答案是否满了,如果满了,则:
if (full) { //如果答案满了,不管是否正确,只要满了,下面的option按钮就不能被点击 for (UIButton *optionBtn in self.optionView.subviews) { optionBtn.enabled=NO; } }只要点击答案按钮,答案必然没有满,所以做个相反操作:
-(void)answerClick:(UIButton *)answerBtn{ //如果答案满了,不管是否正确,只要满了,下面的option按钮就不能被点击 for (UIButton *optionBtn in self.optionView.subviews) { optionBtn.enabled=YES; } }
(2)以上BUG的第二种解决办法:让option按钮的父控件整个不能与用户交互。
即用以下语句:
self.optionView.userInteractionEnabled=NO;
self.optionView.userInteractionEnabled=YES;
代替上面的for循环。
但是除了以上两处之外,还要设置一处。就是因为我们判断了只要答案满了,那么父控件就不能交互按钮不能点击,虽然通过点击答案就能恢复交互。但是特殊情况是:我们点击满了,然后直接跳转到“下一题”,此时父控件依然是被锁定不能交互的。所以需要在“跳转到下一题”的方法中,设置父控件能交互。即
- (IBAction)nextQuestion { self.optionView.userInteractionEnabled=YES; }
或者,最根本的是在添加option按钮的那个方法中设置上面那句话:
-(void)addOptionBtn:(NSQuestion *)question{ self.optionView.userInteractionEnabled=YES; }
(3)到了最后一题,虽然“下一题”按钮被之前做了判断不能点击,但是如果答案答对了系统会继续跳到下一题,这个时候依然会崩溃,所以需要做个判断,如果是最后一题,则……弹框。
——以下语句的原理在于:如果我们正在回答的时最后一道题,那么答对之后,它会继续调用nextQuestion方法,这个时候我们就判断它是否是最后一道题,如果是,则弹框。
——这里的弹框,我们用不到代理,但是为了复习代理知识,把self(控制器)设置为它的代理。
- (IBAction)nextQuestion { if (self.index==self.questions.count-1) { UIAlertView *alert=[[UIAlertView alloc]initWithTitle:@"恭喜" message:@"闯关成功!" delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"好的", nil]; [alert show]; return; } }
——然后在开头的地方遵守协议
@interface ViewController ()<UIAlertViewDelegate>
——最后可以实现协议方法,也相当于可以实现监听。比如下面这个按钮可以监听用户点击了哪个按钮,并可以做一些反应,比如输入是点击了哪个按钮序号。
-(void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex{ NSLog(@"%d",buttonIndex); }
(4)延伸一下,另一种提示框。ActionSheet
——提示框的展示稍有区别,它的出现是“在哪个视图中出现”,还有其他出现方式。
- (IBAction)nextQuestion { if (self.index==self.questions.count-1) { UIActionSheet *sheet=[[UIActionSheet alloc]initWithTitle:@"恭喜通关!" delegate:nil cancelButtonTitle:@"取消" destructiveButtonTitle:@"确定" otherButtonTitles:@"其他", nil]; [sheet showInView:self.view]; return; } }
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。