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

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

内容简介:本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 利用模态视图实现带黑色蒙版的底部弹窗 关闭弹窗


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

查看所有标签

猜你喜欢:

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

这就是搜索引擎

这就是搜索引擎

张俊林 / 电子工业出版社 / 2012-1-1 / 45.00元

搜索引擎作为互联网发展中至关重要的一种应用,已经成为互联网各个领域的制高点,其重要性不言而喻。搜索引擎领域也是互联网应用中不多见的以核心技术作为其命脉的领域,搜索引擎各个子系统是如何设计的?这成为广大技术人员和搜索引擎优化人员密切关注的内容。 本书的最大特点是内容新颖全面而又通俗易懂。对于实际搜索引擎所涉及的各种核心技术都有全面细致的介绍,除了作为搜索系统核心的网络爬虫、索引系统、排序系统、......一起来看看 《这就是搜索引擎》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具