自定义模式对话框

首先在故事板中拖入一个UIViewController,设计你的UI。我们以下面的例子为例:

在这个ViewController中,上半部分我们将设置为透明(通过代码设置),而下半部分是3个UIButton。

在Identity面板中,将Class 设置为一个新的UIViewController子类。然后创建这个UIViewController子类。

在故事板中,选中3个按钮所在的父UIView,即上图中的containerView,添加如下布局约束:

打开助手编辑器,为最下面一个约束Bottom Space to在创建IBOutlet menuBottomConstraint。
并在viewDidLoad方法中,加入代码:

self.view.backgroundColor = UIColor(white: 0.3, alpha: 0.3)
menuBottomConstraint.constant = -128

在viewDidAppear方法中:
super.viewDidAppear(animated)
self.view.layoutIfNeeded()

UIView.animateWithDuration(0.2) {
self.menuBottomConstraint.constant = 0
self.view.layoutIfNeeded()
}

然后在故事板中,在需要显示这个对话框的Scene中,创建一个segue导航到这个我们的自定义对话框。选择segue,在属性面板中进行如下设置(注意,Animates设置为false,Presentation和Transition要设置为Default,否则背景不会透明):


在需要显示对话框的ViewController的prepareForSegue方法中:
if segue.identifier == “ContactUsController” {
if let vc=segue.destinationViewController as? UIViewController{
vc.modalPresentationStyle =
UIModalPresentationStyle.OverCurrentContext;

}

}

运行程序,效果如下:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值