UITabBarController上的WYPopoverController下降

时间:2015-04-23 15:25:51

标签: ios swift uitabbarcontroller modalviewcontroller

我在UITabBarCOntroller上创建按钮,并尝试在应用程序的所有屏幕上调用模态视图。我尝试使用WYPopoverController作为解决方案 我的UITabBarController类是

class PlanetTabBarController: UITabBarController, WYPopoverControllerDelegate {

override func viewDidLoad() {
    super.viewDidLoad()
    self.tabBar.tintColor = kTintColor

    var items = self.tabBar.items as! [UITabBarItem]
    let centredTabBar:UITabBarItem = items[2]
    self.tabBar.layer.borderWidth = 0.50

    centredTabBar.image = UIImage()
    self.tabBar.layer.borderColor = UIColor.clearColor().CGColor
    self.tabBar.layer.borderWidth = 0

    self.tabBar.shadowImage = UIImage()
   // self.tabBar.backgroundImage = ktabBarImage
    self.tabBar.backgroundImage?.imageWithAlignmentRectInsets

    print( UIDevice.currentDevice().modelName)
    if( UIDevice.currentDevice().modelName != "iPhone 6" && UIDevice.currentDevice().modelName != "iPhone 6 Plus"){
       self.tabBar.backgroundImage = ktabBarImage 
    }
    if( UIDevice.currentDevice().modelName == "iPad 2" ){
        self.tabBar.backgroundImage = ktabBarImage
    }



        if let font = UIFont(name: "Avenir-Black", size: 10) {
            let appearance = UITabBarItem.appearance()
            let attributes = [NSFontAttributeName:font]
            appearance.setTitleTextAttributes(attributes, forState: UIControlState.Normal)

        }


    let buttonImage:UIImage = UIImage(named: "tab_planet")!

    var button: UIButton = UIButton.buttonWithType(UIButtonType.Custom) as! UIButton
    button.frame = CGRectMake(0.0, 0.0, buttonImage.size.width, buttonImage.size.height)
    button.setBackgroundImage(buttonImage, forState: UIControlState.Normal)

    var heightDifference:CGFloat = buttonImage.size.height - self.tabBar.frame.size.height
    if (heightDifference < 0){
        button.center = self.tabBar.center
        button.center.y = self.tabBar.center.y - 5
    }else{
        var center:CGPoint = self.tabBar.center
        center.y = center.y - heightDifference/2.0 - 5
        button.center = center
    }
    button.addTarget(self, action: "addPlanet:", forControlEvents: .TouchUpInside)
    self.view.addSubview(button)






}

func addPlanet(sender: UIButton!) {
    self.showAddPlan()
}

func showAddPlan(){

    var contentViewController =  UIStoryboard(name: "AddPlan", bundle: nil).instantiateViewControllerWithIdentifier("AddPlanController") as? AddPlanController


    var popoverController = WYPopoverController(contentViewController: contentViewController)
    popoverController.delegate = self

    popoverController.presentPopoverFromRect(CGRectZero, inView: nil, permittedArrowDirections: WYPopoverArrowDirection.None, animated: false) { () -> Void in
        print ("done")
    }






}

func popoverControllerShouldDismissPopover(popoverController: WYPopoverController!) -> Bool {
    return false
}

}

但是当我尝试调用我的AddPlanController时,它崩溃并出现错误

** Planet.AddPlanController类的实例0x7fe4a48849d0已取消分配,而键值观察者仍在其中注册。目前的观察资料:(  上下文:0x0,属性:0x7fe4a4915e00&gt; **

请给我一个建议,如何从UITabBar上的按钮调用模态视图控制器,这将在所有屏幕上调用阴影bg。 =(

1 个答案:

答案 0 :(得分:0)

您必须保持对popoverController的引用,直到它可见,但现在当您从showAddPlan方法返回时,它会被取消分配。

从您的函数移动popoverController的定义,它将起作用