iOS 利用模态视图实现带黑色蒙版的底部弹窗

栏目: IOS · 发布时间: 5年前

内容简介:本demo仅适用于iOS8及以上系统。1、打开storyboard 拖一个UIViewcontroller出来,并与class相关联2、拖出一个UIView作为弹窗视图的容器,容器里放置弹窗的内容,容器高度根据具体需求放置。容器放在最底部

本demo仅适用于iOS8及以上系统。

使用autolayout+storyboard实现弹窗

第一步、storyboard创建界面

1、打开storyboard 拖一个UIViewcontroller出来,并与class相关联

2、拖出一个UIView作为弹窗视图的容器,容器里放置弹窗的内容,容器高度根据具体需求放置。容器放在最底部

3、放置一个UIButton在容器View的上方间距为0,并把UIButton设置为黑色(用于实现蒙版效果及点击空白处关闭弹窗)

4、约束。底部容器打left、right、bottom、height这个约束。UIButton打 left、right、top、bottom约束 如图

iOS 利用模态视图实现带黑色蒙版的底部弹窗

底部容器约束

iOS 利用模态视图实现带黑色蒙版的底部弹窗

UIButton约束

5、约束。将底部容器的bottom约束编辑修改 如图

iOS 利用模态视图实现带黑色蒙版的底部弹窗

修改容器bottom约束

iOS 利用模态视图实现带黑色蒙版的底部弹窗

修改容器bottom约束

iOS 利用模态视图实现带黑色蒙版的底部弹窗

修改容器bottom约束

6、找到底部容器的bottom约束拉线到对应的UIViewController 如图

iOS 利用模态视图实现带黑色蒙版的底部弹窗 拉线

第二步、设置蒙版及弹窗动画

1、修改UIButton的透明度并把UIViewController的View的背景色设置为透明 如图

iOS 利用模态视图实现带黑色蒙版的底部弹窗 设置透明度

//千万别设置view的alpha 设置alpha 会导致view下的所有子视图都变透明
self.view.backgroundColor = [UIColor clearColor];

//设置按钮透明度
self.dismissBtn.alpha = 0.5f;
self.dismissBtn.backgroundColor = [UIColor blackColor];

2、实现弹窗动画,在viewDidAppear中实现,这样才可以看到整个动画过程 如图

iOS 利用模态视图实现带黑色蒙版的底部弹窗 修改约束

//视图显示完 弹出弹窗
- (void)viewDidAppear:(BOOL)animated {
    [super viewDidAppear:animated];
    
    //更改视图 底部约束
    self.viewBottomConstraint.constant = 0;
    
    //执行动画
    [UIView animateWithDuration:0.25 animations:^{
        
        //强制更新约束
        [self.view layoutIfNeeded];
    }];
}

3、弹出模态视图 如图

iOS 利用模态视图实现带黑色蒙版的底部弹窗 模态视图

请注意看截图,该方法所在类为ViewController

#pragma mark- 按钮点击事件
- (void)popBtn:(UIButton *)btn {
    
    UIStoryboard * sb = [UIStoryboard storyboardWithName:@"Main" bundle:nil];
    QWPopupWindowVC * vc = [sb instantiateViewControllerWithIdentifier:@"QWPopupWindowVC"];
    vc.providesPresentationContextTransitionStyle = YES;
    vc.definesPresentationContext = YES;
    vc.modalPresentationStyle = UIModalPresentationOverCurrentContext;
    [self presentViewController:vc animated:NO completion:nil];
    
}

几个属性的解释

解释内容摘至博客园 返回主页不打扰是我的温柔 http://www.cnblogs.com/SenDylan/p/3953832.html

providesPresentationContextTransitionStyle

iOS 利用模态视图实现带黑色蒙版的底部弹窗

definesPresentationContext

iOS 利用模态视图实现带黑色蒙版的底部弹窗

modalPresentationStyle

iOS 利用模态视图实现带黑色蒙版的底部弹窗

部分类容读起来怪怪的,不清楚是不是翻译软件的原因。

4、关闭弹窗

iOS 利用模态视图实现带黑色蒙版的底部弹窗 关闭弹窗


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Perl语言入门

Perl语言入门

[美] Randal L.Schwartz、Tom Phoenix / 李晓峰 / 中国电力出版社 / 2002-8 / 48.00元

本书第一版于1993年问世,并从此成为畅销书。本书由Perl社区最著名、最活跃的两位成员写成,是Perl程序设计语言的精髓指南。 Perl最初只是Unix系统管理员的一个工具,在工作日里被用在无数的小任务中。从那以后,它逐步发展成为一种全功能的程序设计语言,特别是在各种计算平台上,它被用作Web编程、数据库处理、XML处理以及系统管理——它能够完成所有这些工作,同时仍然是处理小的日常工作的完......一起来看看 《Perl语言入门》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具