UIPopoverController、Xcode 6、IOS 8 使用 Swift
Posted
技术标签:
【中文标题】UIPopoverController、Xcode 6、IOS 8 使用 Swift【英文标题】:UIPopoverController, Xcode 6, IOS 8 using Swift 【发布时间】:2014-09-16 12:16:06 【问题描述】:我在使用 swift 让 UIPopover 出现时遇到了一些问题。被注释掉的代码在 Objective-C 中运行良好,但在 Swift 中无法运行。当我在视图控制器中点击 + 时,我确实在调试器中获得了“点击”,但是没有出现弹出窗口。
class PlayerInformationTableViewController: UITableViewController, NSFetchedResultsControllerDelegate, UIPopoverControllerDelegate
@IBOutlet weak var addBarButtonItem: UIBarButtonItem!
var playerInformationViewController = PlayerInformationViewController()
var popover:UIPopoverController? = nil
override func viewDidLoad()
super.viewDidLoad()
/*
//setup the popover
_cuesPopoverViewController = [self.storyboard instantiateViewControllerWithIdentifier:@"CuesPopoverViewController"];
self.cuesPopover = [[UIPopoverController alloc] initWithContentViewController:_cuesPopoverViewController];
self.cuesPopover.popoverContentSize = CGSizeMake(540, 300);
self.cuesPopover.delegate = self;
*/
playerInformationViewController.storyboard?.instantiateViewControllerWithIdentifier("PlayerInformationViewController")
popover?.contentViewController = playerInformationViewController
popover?.popoverContentSize = CGSizeMake(300, 300)
popover?.delegate = self
// Uncomment the following line to preserve selection between presentations
// self.clearsSelectionOnViewWillAppear = false
// Uncomment the following line to display an Edit button in the navigation bar for this view controller.
// self.navigationItem.rightBarButtonItem = self.editButtonItem()
@IBAction func addPopover(sender: AnyObject)
println("Click")
popover?.presentPopoverFromBarButtonItem(addBarButtonItem, permittedArrowDirections: UIPopoverArrowDirection.Any, animated: true)
解决方案
override func viewDidLoad()
super.viewDidLoad()
@IBAction func addPopover(sender: AnyObject)
var popoverViewController = self.storyboard?.instantiateViewControllerWithIdentifier("PlayerInformationViewController") as UIViewController
popoverViewController.modalPresentationStyle = .Popover
popoverViewController.preferredContentSize = CGSizeMake(450, 450)
let popoverPresentationViewController = popoverViewController.popoverPresentationController
popoverPresentationViewController?.permittedArrowDirections = .Any
popoverPresentationViewController?.delegate = self
popoverPresentationViewController?.barButtonItem = sender as UIBarButtonItem
presentViewController(popoverViewController, animated: true, completion: nil)
【问题讨论】:
您在任何地方都在使用?.
。这意味着如果某事确实是nil
,您将不会发现这一点。作为调试的第一步,尝试解析选项(使用if let x = ..
获取它们的值)并使用该值。
【参考方案1】:
这里是 ios 8 的一个简单示例。在 iOS 8 中使用自适应 api 呈现弹出框。
class PlayerInformationTableViewController: UITableViewController, UIPopoverPresentationControllerDelegate, NSFetchedResultsControllerDelegate
...
@IBAction func addPopover(sender: UIBarButtonItem)
let playerInformationViewController = PlayerInformationViewController()
playerInformationViewController.modalPresentationStyle = .Popover
playerInformationViewController.preferredContentSize = CGSizeMake(300, 300)
let popoverPresentationViewController = playerInformationViewController.popoverPresentationController
popoverPresentationViewController?.permittedArrowDirections = .Any
popoverPresentationViewController?.delegate = self
popoverPresentationController?.barButtonItem = sender
presentViewController(playerInformationViewController, animated: true, completion: nil)
func adaptivePresentationStyleForPresentationController(controller: UIPresentationController!) -> UIModalPresentationStyle
return .None
【讨论】:
这很好用,有一个小错误。 popoverPresentationViewController?.barButtonItem = 作为 UIBarButtonItem 的发送者。既然弹出框“弹出”了,为什么它不显示我在界面构建器中的内容? 上面这段代码的问题是,我正在从代码中实例化一个新的viewController。因此,如果您使用 storyboard 来实例化您的 viewController,那可能会解决您现在在界面构建器中显示 UI 元素的问题。 如何添加 playerInformationViewController.storyboard?.instantiateViewControllerWithIdentifier("PlayerInformationViewController") 以使用我的故事板,而不是创建新的视图控制器? 如果您的应用程序使用故事板,请使用 self.storyboard?.instantiateViewControllerWithIdentifier("PlayerInformationViewControllerIdentifier")。 如果我添加 self.storyboard? 仍然显示一个新的 UIViewController?我想用作弹出框的视图控制器是 PlayerInformationViewController【参考方案2】:使用 xib 中的 contentView 显示弹出框
func showPopover(sender: AnyObject)
let contentViewController = UINib(nibName: "ContentVC", bundle: nil).instantiateWithOwner(nil, options: nil)[0] as ContentVC
contentViewController.modalPresentationStyle = UIModalPresentationStyle.Popover
var detailPopover: UIPopoverPresentationController = contentViewController.popoverPresentationController!
detailPopover.delegate = self
detailPopover.barButtonItem = sender as UIBarButtonItem
detailPopover.permittedArrowDirections = UIPopoverArrowDirection.Any
presentViewController(contentViewController,
animated: true, completion:nil)
Next 允许在 iPhone 上制作非全屏 PopoverView 为此不要忘记继承 MainViewController: UIPopoverPresentationControllerDelegate 并将委托设置为 PopoverView
func adaptivePresentationStyleForPresentationController(controller: UIPresentationController!) -> UIModalPresentationStyle
return .None
【讨论】:
【参考方案3】:看起来您的popover
是nil
。你在哪里分配/实例化它?
尝试改变这个:
popover?.presentPopoverFromBarButtonItem(addBarButtonItem, permittedArrowDirections: UIPopoverArrowDirection.Any, animated: true)
到这里:
if let pop = popover
pop.presentPopoverFromBarButtonItem(addBarButtonItem, permittedArrowDirections: UIPopoverArrowDirection.Any, animated: true)
else
NSLog("Error: Popover was nil")
我想您会在控制台中看到该错误消息。在您的PlayerInformationTableViewController
的.XIB 中,您是否有UIPopoverController
?
如果是这样,您可能需要确保 var popover
是 (1) 在您的 awakeFromNib
中手动实例化,或者它是 @IBOutlet
并且连接正确。
或者,您可以简单地使用您的playerInformationViewController
中已经存在的popover
吗?
【讨论】:
以上是关于UIPopoverController、Xcode 6、IOS 8 使用 Swift的主要内容,如果未能解决你的问题,请参考以下文章
我逐字复制了 UIPopoverController 代码,该代码适用于 xcode 3.2 上的 ipad,但不适用于 xcode 4.2
Xcode5 iOS7 - UIPopoverController 角半径
带有 UIImagePickerController 和 UIPopoverController 的 exc_bad_access