UIPopoverController 是iPad特有控件,iOS9之前,在iOS上也可以使用,在iOS9之后,只能用于Pad上。

如果非要在iOS上使用,编译不会有问题,运行后会崩溃,报错如下:

Terminating app due to uncaught exception 'NSInvalidArgumentException', 
reason: '-[UIPopoverController initWithContentViewController:] called when not running under UIUserInterfaceIdiomPad.'

因此,这里的介绍都是给予iPad来的,此文的Demo也得运行在Pad模拟器或pad真机上。

---------------------------------------------------------------------

如果想直接看最简单实现方式:

点击这里查看

---------------------------------------------------------------------

下面是具体讲解。

1、关于UIPopoverController

其实就是类似图中这样的菜单弹出框。

在iOS上,我们可能要自己自定义或用三方封装好的菜单控件,但在pad上,我们可以直接使用系统提供的控件,简单快捷。

要想显示一个UIPopoverController,需要经过下列三步骤:

1)设置内容控制器:
由于UIPopoverController直接继承自NSObject,不具备可视化的能力,因此UIPopoverController上面的内容必须由另外一个继承自UIViewController的控制器来提供,这个控制器称为“内容控制器” 2)设置内容的尺寸:
显示出来占据多少屏幕空间 3)设置显示的位置:
从哪个地方冒出来

这里有几点注意 :

1、UIPopoverController不是一个view,不能直接显示或add到父view上,可以理解成一个盒子容器,盒子里面显示的内容需要一个额外的uiviewcontroller来呈现。

2、设置大小,最好在盒子里面的控制器来设置,每个uiviewcontroller都有一个 preferredContentSize 属性来设置size。

3、当然,如果想直接设置大小,也可以,不过如果内容控制器里设置了 preferredContentSize 大小 self.preferredContentSize = CGSizeMake(200, 200); 那么 self.popOver.popoverContentSize 将无意义。

2、属性介绍

设置内容的尺寸有2种方法:
@property (nonatomic) CGSize popoverContentSize;

- (void)setPopoverContentSize:(CGSize)size animated:(BOOL)animated;

以上方法和属性都是UIPopoverController的

如果通过内容控制器设置内容尺寸
在iOS 7之前
@property (nonatomic,readwrite) CGSize contentSizeForViewInPopover; 从iOS 7开始
@property (nonatomic) CGSize preferredContentSize;
以上属性都是UIViewController的

常用属性

代理对象
@property (nonatomic, assign) id <UIPopoverControllerDelegate> delegate; 是否可见
@property (nonatomic, readonly, getter=isPopoverVisible) BOOL popoverVisible; 箭头方向
@property (nonatomic, readonly) UIPopoverArrowDirection popoverArrowDirection; 关闭popover(让popover消失)
- (void)dismissPopoverAnimated:(BOOL)animated;

设置显示的位置

()围绕着一个UIBarButtonItem显示(箭头指定那个UIBarButtonItem)

- (void)presentPopoverFromBarButtonItem:(UIBarButtonItem *)item permittedArrowDirections:(UIPopoverArrowDirection)arrowDirections animated:(BOOL)animated;

item :围绕着哪个UIBarButtonItem显示

arrowDirections :箭头的方向

animated :是否通过动画显示出来

()围绕着某一块特定区域显示(箭头指定那块特定区域)

- (void)presentPopoverFromRect:(CGRect)rect inView:(UIView *)view permittedArrowDirections:(UIPopoverArrowDirection)arrowDirections animated:(BOOL)animated;

rect :指定箭头所指区域的矩形框范围(位置和尺寸),以view的左上角为坐标原点

view :rect参数是以view的左上角为坐标原点(,)

arrowDirections :箭头的方向

animated :是否通过动画显示出来

代理方法

#pragma mark-代理方法
// popoverController消失的时候调用
-(void)popoverControllerDidDismissPopover:(UIPopoverController *)popoverController { }
// popoverController的位置改变的时候调用(如竖屏变横屏)
-(void)popoverController:(UIPopoverController *)popoverController willRepositionPopoverToRect:(inout CGRect *)rect inView:(inout UIView *__autoreleasing *)view { }
// 用来决定用户点击了蒙版后,popoverController是否可以dismiss,返回YES代表可以,返回NO代表不可以
-(BOOL)popoverControllerShouldDismissPopover:(UIPopoverController *)popoverController {
return NO;
}

3、Demo代码介绍

一个是显示控制器文件

一个是popover的容器控制器文件

显示控制器:

    var popOver:UIPopoverController!

    override func viewDidLoad() {
super.viewDidLoad() view.backgroundColor = UIColor.white self.navigationItem.title = "必须用pad模拟器或pad测试" let popVC = TestPopoverViewController()
popVC.delegate = self //代理为了点击内部的处理事件 //添加contentview子视图,大小建议在子视图内部设置
popOver = UIPopoverController(contentViewController: popVC)
popOver.delegate = self //设置pop背景色,一般是为了和里面的content背景色一致,不然默认情况下会造成色差
popOver.backgroundColor = UIColor.white //哪些控件可以继续跟用户进行正常交互。这样的话,点击区域外的控件就不会让UIPopoverController消失了
//popOver.passthroughViews = [view] //这句话加上后,点击蒙版,pop就不会消失,因为设置了view的交互可用 //导航点击弹出
self.navigationItem.leftBarButtonItem = UIBarButtonItem(barButtonSystemItem: .action, target: self, action: #selector(self.testNavPop)) //按钮点击弹出
testBtnPop() }

这里我构造了两种弹出方式:

1-导航栏位置   2-页面自定义位置,用一个按钮点击弹出

1-导航栏位置弹出

 func testNavPop() {
popOver.present(from: self.navigationItem.leftBarButtonItem!, permittedArrowDirections: .any, animated: true) }

2-按钮位置弹出

/// 在按钮弹出
func btnClick(sender:UIButton) {
//这种是紧靠着按钮位置弹出
//popOver.present(from: sender.bounds, in: sender, permittedArrowDirections: .any, animated: true) //自定义弹出位置,比如这里我设置y上面与按钮间隔20
popOver.present(from: CGRect(x: sender.bounds.origin.x, y: sender.bounds.origin.y+, width: sender.bounds.size.width, height: sender.bounds.size.height), in: sender, permittedArrowDirections: .any, animated: true) }

代理事件:

/// popover代理
extension TestPadViewController:UIPopoverControllerDelegate{
//popoverController消失的时候调用
func popoverControllerDidDismissPopover(_ popoverController: UIPopoverController) {
print("popoverControllerDidDismissPopover")
} //popoverController的位置改变的时候调用(如竖屏变横屏)
func popoverController(_ popoverController: UIPopoverController, willRepositionPopoverTo rect: UnsafeMutablePointer<CGRect>, in view: AutoreleasingUnsafeMutablePointer<UIView>) {
print("willRepositionPopoverTo")
} //用来决定用户点击了蒙版后,popoverController是否可以dismiss,返回YES代表可以,返回NO代表不可以
func popoverControllerShouldDismissPopover(_ popoverController: UIPopoverController) -> Bool {
return true
}
} /// popover容器内点击事件的代理
extension TestPadViewController:TestPopoverViewControllerDelegate{
internal func TestPopoverViewControllerDidSelect(index: NSInteger) {
popOver.dismiss(animated: true)
print("click \(index)")
} }

容器控制器:

var tableview:UITableView!

    var data = ["列表1","列表2","列表3","列表4","列表5","列表6","列表7","列表8"]

    weak var delegate:TestPopoverViewControllerDelegate?

    override func viewDidLoad() {
super.viewDidLoad()
view.backgroundColor = UIColor.white //设置pop框最大高度为150
let maxH = min(, *data.count) self.preferredContentSize = CGSize(width: , height: maxH) tableview = UITableView(frame: self.view.bounds, style: .plain)
view.addSubview(tableview)
tableview.dataSource = self
tableview.delegate = self
tableview.estimatedRowHeight = }

用一个列表做示例。

Demo下载,点击这里

~~

Pad控件 UIPopoverController的介绍与使用(Pad的专属菜单控件、Swift版本)的更多相关文章

  1. 使用Duilib开发Windows软件(2)——控件的基本介绍

    XML 先学习xml https://www.w3cschool.cn/xml/xml-xml-tutorialhc4o1t5m.html 控件 上图是我们下载的NIM_Duilib_Framewor ...

  2. ActiveX控件的基本操作方法以及如何在VS2010下使用控件

    在此,小编就介绍下ActiveX控件的基本操作方法以及如何在VS2010下使用控件,我们以一个程序为例, (1)      打开VS2010编译器(右键以管理员身份运行,因为ActiveX需要注册), ...

  3. Asp.net 菜单控件

    本文介绍的菜单控件采用的css 和ul list来显示菜单,生成的html小,无需javascript支持,对大部分的浏览器都支持,除ie6要单独修改css也可以使其支持. 通过本文可以了解asp.n ...

  4. 自写JQ控件-树状菜单控件[demo下载]

    一个多月没有写博客了,最近也弄一个基于JQ的树状菜单控件,在此分享给大家.另外呢,通过这个例子分享一下怎么写JQ控件的. 事实上工作中,也是经常遇到的,有些时候自己想实现一些前端效果,用网上一些插件吧 ...

  5. 简洁的Asp.net菜单控件

    http://www.cnblogs.com/ruinet/archive/2009/11/10/1599984.html asp.net自带的菜单控件采用的table和javascript,导致生成 ...

  6. Android 使用代码主动去调用控件的点击事件(模拟人手去触摸控件)

    使用代码主动去调用控件的点击事件(模拟人手去触摸控件) //View 可以是LinearLayout,Button,TextView View.performClick();

  7. 实用的树形菜单控件tree

     jQuery plugin: Treeview  这个插件能够把无序列表转换成可展开与收缩的Tree. jQuery plugin: Treeview  jQuery  jstree  jsTree ...

  8. html树形菜单控件

    html树形菜单控件  链接 http://www.ithao123.cn/content-713974.html         jQuery plugin: Treeview  这个插件能够把无序 ...

  9. Android两个控件叠在一起,如何让被挡住的控件显示出来

    Android两个控件叠在一起,如何让被挡住的控件显示出来 问题 : 两个控件叠在一起,如何让被挡住的控件显示出来? 比如A,B两个控件,A被B挡住,目前A要显示出来,B不能被隐藏,A的高度只有那么一 ...

随机推荐

  1. block、inline、inline-block对比

    display:block 1.block元素会独占一行,多个block元素会各种新起一行.默认情况下,block元素宽度自动填满其父元素容器: 2.block元素可以设置width和height属性 ...

  2. C/C++中慎用宏(#define)

    宏的定义在程序中是非常有用的,但是使用不当,就会给自身造成很大的困扰.通常这种困扰为:宏使用在计算方面. 本例子主要是在宏的计算方面,很多时候,大家都知道定义一个计算的宏,对于编译和编程是多么的有用. ...

  3. 转:JSP 分页显示数据 (Oracle)

    JSP 分页显示数据 (Oracle) 标签: Oracle分页JSP分页 2013-11-19 20:40 3598人阅读 评论(1) 收藏 举报  分类: Web(11)  版权声明:本文为博主原 ...

  4. Android开发8:数据存储(二)——SQLite数据库和ContentProvider的使用

    前言 啦啦啦各位小伙伴们许久不见了~学期末和过年期间自己忙着做其他事没能及时更新Android开发系列课程的博客,实在是罪过罪过~ 好啦~废话不多说,进入我们今天的主题.今天我们将和大家学习其他的数据 ...

  5. nodejs爬虫——汽车之家所有车型数据

    应用介绍 项目Github地址:https://github.com/iNuanfeng/node-spider/ nodejs爬虫,爬取汽车之家(http://www.autohome.com.cn ...

  6. memcached学习总结

    一.介绍1.基于libevent的事件处理 libevent是一套跨平台的事件处理接口的封装,能够兼容包括这些操作系统:Windows/Linux/BSD/Solaris 等操作系统的的事件处理.包装 ...

  7. UWP: 体验应用内购新接口——StoreContext类

    Windows 1607 版本(内部版本 14393)之后,微软在 SDK 添加了一些与应用商店相关的新接口,像应用试用与购买.应用内购等.这些接口相对于原来的接口要方便很多.就拿应用内购来说,以前的 ...

  8. C#基础——结构体

    集合:数组:同一类型,固定长度集合:不同类型,不固定长度 要使用集合,必须先引用命名空间:using System.Collections; 定义:ArrayList arr = new ArrayL ...

  9. C#自动弹出窗口并定时自动关闭

    最近做个小项目,用到一个小功能:后台线程定时查询数据库,不符合条件的记录弹出消息提醒(在窗口最前面),并且过几秒钟再自动关闭弹出的窗口. 所以从网上找来资料,如下: WinForm 下实现一个自动关闭 ...

  10. 移动H5开发入门知识,CSS的单位汇总与用法

    说到css的单位,大家应该首先想到的是px,也就是像素,我们在网页布局中一般都是用px,但是近年来自适应网页布局越来越多,em和百分比也经常用到了.然后随着手机的流行,web app和hybrid a ...