关于模态弹窗点击灰色区域消失
2013-11-02 20:35
232 查看
标题是不是写的很有诗意?我自己也觉得有点儿迷糊,其实就是这样需求:模态弹出来的窗口,需要点击窗口以外的区域,也就是模态区域让这个窗口消失。一般这种场景会出现在iPad里,当你modalPresentationStyle为UIModalPresentationFormSheet时,会有这种需求。网上找了一下,这种东东还真能实现,于是想着UIAlertView是不是也可以实现呢?你猜咋地,竟然真的可以。
其实原理就是在弹框给那个view的window注册一个点击事件,然后在点击事件里判断点击区域是不是模态区域,具体代码如下:
- (IBAction)showAlert:(id)sender {
alert = [[UIAlertView alloc] initWithTitle:@"模态测试"
message:@"请点击四周的模态区域我就消失"
delegate:nil
cancelButtonTitle:@"确定"
otherButtonTitles:nil];
[alert show];
recognizerTap = [[UITapGestureRecognizer alloc] initWithTarget:self
action:@selector(handleTapBehind:)];
[recognizerTap setNumberOfTapsRequired:1];
recognizerTap.cancelsTouchesInView = NO;
[alert.window addGestureRecognizer:recognizerTap];
}
- (void)handleTapBehind:(UITapGestureRecognizer *)sender{
if (sender.state == UIGestureRecognizerStateEnded){
CGPoint location = [sender locationInView:nil];
if (![alert pointInside:[alert convertPoint:location fromView:alert.window] withEvent:nil]){
[alert.window removeGestureRecognizer:sender];
[alert dismissWithClickedButtonIndex:0
animated:YES];
}
}
}
看着很简单哈~
代码下载:alertTest
参考资料:
need
to dismiss the modalview form sheet controller when tap occurs on outside of the view
其实原理就是在弹框给那个view的window注册一个点击事件,然后在点击事件里判断点击区域是不是模态区域,具体代码如下:
- (IBAction)showAlert:(id)sender {
alert = [[UIAlertView alloc] initWithTitle:@"模态测试"
message:@"请点击四周的模态区域我就消失"
delegate:nil
cancelButtonTitle:@"确定"
otherButtonTitles:nil];
[alert show];
recognizerTap = [[UITapGestureRecognizer alloc] initWithTarget:self
action:@selector(handleTapBehind:)];
[recognizerTap setNumberOfTapsRequired:1];
recognizerTap.cancelsTouchesInView = NO;
[alert.window addGestureRecognizer:recognizerTap];
}
- (void)handleTapBehind:(UITapGestureRecognizer *)sender{
if (sender.state == UIGestureRecognizerStateEnded){
CGPoint location = [sender locationInView:nil];
if (![alert pointInside:[alert convertPoint:location fromView:alert.window] withEvent:nil]){
[alert.window removeGestureRecognizer:sender];
[alert dismissWithClickedButtonIndex:0
animated:YES];
}
}
}
看着很简单哈~
代码下载:alertTest
参考资料:
need
to dismiss the modalview form sheet controller when tap occurs on outside of the view
相关文章推荐
- 关于模态弹窗点击灰色区域消失
- 模态弹窗(对话框)点击灰色区域消失
- 模态弹窗,点击黑色半透明区域消失
- 关于点击popupwindow以外区域 popupwindow自动消失问题
- 关于移动端点击a标签去掉背景灰色区域
- 关于点击popupwindow以外区域 popupwindow自动消失问题
- 关于点击popupwindow以外区域 popupwindow自动消失问题
- 关于点击popupwindow以外区域 popupwindow自动消失问题
- Model模态框点击其他除了模态框区域不消失
- PopupWindow(弹窗)点击空白区域和返回键消失
- 关于boostrap中模态框的问题点击后面背景模态框消失的问题
- 关于点击popupwindow以外区域 popupwindow自动消失问题
- jquery: 弹窗点击一下窗口外区域,弹窗消失,而点击窗口内部不会消失
- 关于点击popupwindow以外区域 popupwindow自动消失问题
- 点击外围区域使得popupwindow消失
- 关于自定义UITableViewCell布局点击Cell消失的问题
- 关于View扩展点击区域的误区
- UITextField 点击非文本框区域使键盘消失的三种方法
- 怎么使点击一个popupwindow窗口之外的区域popupwindow消失呢?
- 关于安卓alertdialog你能用到的都在这里了(进出动画,显示位置,背景,设置内容,是否可以点击其他地方消失,屏幕不变暗)