swift UITabBarController 上的浮动按钮
swift floating button on UITabBarController
我有一个包含 3 个部分的标签栏控制器。我还为特殊功能创建了一个浮动按钮,但现在它只在一个部分上。我想添加一次这个按钮并在所有部分显示它。所以你可以通过所有应用程序使用这个按钮。
可能吗?
一个想法可以是将此按钮添加到 UITabBarController。可能吗?你有什么想法吗?
谢谢
您需要将其添加到应用的 window
let del = UIApplication.shared.delegate as! AppDelegate
del.window?.addSubview(btn)
Swift 4
您需要子类 TabBarController 来操作它。
import UIKit
class CustomTabBarViewController: UITabBarController {
let btn = UIButton() //Here create your button
override func viewDidLoad() {
super.viewDidLoad()
//Here set up your button
self.view.insertSubview(btn, belowSubview: self.tabBar) //<--This is important.
//With this call you have a button that is over all view but under the tab bar.
//So if you have a round button that it expanded on click, the expanded
//part could be hidden by the tab bar, if it is near to tab bar.
//Other button's setting if you need
btn.translatesAutoresizingMaskIntoConstraints = false //<- Important
//Because you are adding the button programmatically you need set the
//constraints. to do it, you need set to false the autoresizing mask.
//Here set the constraints.
//These constraints put the button in the lower right corner, over the tab bar
let viewDictionary = ["button":btn, "tabBar":self.tabBar]
let btn_V = NSLayoutConstraint.constraints(withVisualFormat: "V:[button(340)]", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: viewDictionary)
let btn_H = NSLayoutConstraint.constraints(withVisualFormat: "H:[button(340)]", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: viewDictionary)
let btn_POS_V = NSLayoutConstraint.constraints(withVisualFormat: "V:[button]-(-130)-[tabBar]", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: viewDictionary)
let btn_POS_H = NSLayoutConstraint.constraints(withVisualFormat: "H:[button]-(-129)-|", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: viewDictionary)
btn.addConstraints(btn_V)
btn.addConstraints(btn_H)
self.view.addConstraints(btn_POS_H)
self.view.addConstraints(btn_POS_V)
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
/*
// MARK: - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
// Get the new view controller using segue.destinationViewController.
// Pass the selected object to the new view controller.
}
*/
}
这是结果
我有一个包含 3 个部分的标签栏控制器。我还为特殊功能创建了一个浮动按钮,但现在它只在一个部分上。我想添加一次这个按钮并在所有部分显示它。所以你可以通过所有应用程序使用这个按钮。
可能吗?
一个想法可以是将此按钮添加到 UITabBarController。可能吗?你有什么想法吗?
谢谢
您需要将其添加到应用的 window
let del = UIApplication.shared.delegate as! AppDelegate
del.window?.addSubview(btn)
Swift 4
您需要子类 TabBarController 来操作它。
import UIKit
class CustomTabBarViewController: UITabBarController {
let btn = UIButton() //Here create your button
override func viewDidLoad() {
super.viewDidLoad()
//Here set up your button
self.view.insertSubview(btn, belowSubview: self.tabBar) //<--This is important.
//With this call you have a button that is over all view but under the tab bar.
//So if you have a round button that it expanded on click, the expanded
//part could be hidden by the tab bar, if it is near to tab bar.
//Other button's setting if you need
btn.translatesAutoresizingMaskIntoConstraints = false //<- Important
//Because you are adding the button programmatically you need set the
//constraints. to do it, you need set to false the autoresizing mask.
//Here set the constraints.
//These constraints put the button in the lower right corner, over the tab bar
let viewDictionary = ["button":btn, "tabBar":self.tabBar]
let btn_V = NSLayoutConstraint.constraints(withVisualFormat: "V:[button(340)]", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: viewDictionary)
let btn_H = NSLayoutConstraint.constraints(withVisualFormat: "H:[button(340)]", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: viewDictionary)
let btn_POS_V = NSLayoutConstraint.constraints(withVisualFormat: "V:[button]-(-130)-[tabBar]", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: viewDictionary)
let btn_POS_H = NSLayoutConstraint.constraints(withVisualFormat: "H:[button]-(-129)-|", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: viewDictionary)
btn.addConstraints(btn_V)
btn.addConstraints(btn_H)
self.view.addConstraints(btn_POS_H)
self.view.addConstraints(btn_POS_V)
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
/*
// MARK: - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
// Get the new view controller using segue.destinationViewController.
// Pass the selected object to the new view controller.
}
*/
}
这是结果