前言:
此种方式实现只适用于pad开发,在iPhone上是无效的。
实现:
比如我在界面上有一个按钮,点击按钮,在按钮旁边弹出一个Pop框。
1、按钮点击事件
btn.addTarget(self, action: #selector(self.popShow), for: .touchUpInside)
2、事件处理
/// 弹框选择条件 /// /// - Parameter sender: <#sender description#> func popShow(sender:UIButton) { let popVC = ExerciseLibPopViewController() popVC.modalPresentationStyle = .popover popVC.preferredContentSize = CGSize(width: 111, height: 2*44.0) popVC.popoverPresentationController?.sourceView = sender popVC.popoverPresentationController?.sourceRect = sender.bounds popVC.popoverPresentationController?.delegate = self self.present(popVC, animated: true, completion: nil) }
其中,popover类有一个代理:
extension xxxViewController : UIPopoverPresentationControllerDelegate { func popoverPresentationControllerShouldDismissPopover(_ popoverPresentationController: UIPopoverPresentationController) -> Bool { print("popoverPresentationControllerShouldDismissPopover") // 处理你要做的 return true }}
类似效果如下:
最后小Tips:
1、如果这里需要把上图的小箭头背景色改成其他颜色(和里面颜色一致)
加上这句即可:
popVC.popoverPresentationController?.backgroundColor = UIColor.white
2、如果想改变弹出框位置,修改这句即可:
// 将bounds改成CGRect(x,y,w,h)自己构造参数popVC.popoverPresentationController?.sourceRect = sender.bounds
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。
新闻热点
疑难解答