UIBarButtonItem в панели навигации программно?
Я искал это решение в течение некоторого времени, но не получил ни одного. например, одним из решений является
self.navigationItem.setRightBarButtonItem(UIBarButtonItem(barButtonSystemItem: .Stop, target: self, action: nil), animated: true)
этот код добавит кнопку с изображением" стоп". Подобно этого, есть и другие решения с "поиск, "обновить" и т. д. Но что делать, если я хочу добавить кнопку программно с изображением, которое я хочу?
8 ответов:
Пользовательское изображение кнопки без установки рамки кнопки:
можно использовать
init(image: UIImage?, style: UIBarButtonItemStyle, target: Any?, action: Selector?)
для инициализации нового элемента с использованием указанного изображения и других свойств.let button1 = UIBarButtonItem(image: UIImage(named: "imagename"), style: .plain, target: self, action: Selector("action")) // action:#selector(Class.MethodName) for swift 3 self.navigationItem.rightBarButtonItem = button1
проверить это Apple Doc. ссылка
UIBarButtonItem с пользовательским изображением кнопки с помощью кнопки frame
на
Swift 3.0
let btn1 = UIButton(type: .custom) btn1.setImage(UIImage(named: "imagename"), for: .normal) btn1.frame = CGRect(x: 0, y: 0, width: 30, height: 30) btn1.addTarget(self, action: #selector(Class.Methodname), for: .touchUpInside) let item1 = UIBarButtonItem(customView: btn1) let btn2 = UIButton(type: .custom) btn2.setImage(UIImage(named: "imagename"), for: .normal) btn2.frame = CGRect(x: 0, y: 0, width: 30, height: 30) btn2.addTarget(self, action: #selector(Class.MethodName), for: .touchUpInside) let item2 = UIBarButtonItem(customView: btn2) self.navigationItem.setRightBarButtonItems([item1,item2], animated: true)
на
Swift 2.0
и старшеlet btnName = UIButton() btnName.setImage(UIImage(named: "imagename"), forState: .Normal) btnName.frame = CGRectMake(0, 0, 30, 30) btnName.addTarget(self, action: Selector("action"), forControlEvents: .TouchUpInside) //.... Set Right/Left Bar Button item let rightBarButton = UIBarButtonItem() rightBarButton.customView = btnName self.navigationItem.rightBarButtonItem = rightBarButton
или просто использовать init (customView:) как
let rightBarButton = UIBarButtonItem(customView: btnName) self.navigationItem.rightBarButtonItem = rightBarButton
Для Системы UIBarButtonItem
let camera = UIBarButtonItem(barButtonSystemItem: .Camera, target: self, action: Selector("btnOpenCamera")) self.navigationItem.rightBarButtonItem = camera
для набора более 1 элементов используйте
rightBarButtonItems
или по левой сторонеleftBarButtonItems
let btn1 = UIButton() btn1.setImage(UIImage(named: "img1"), forState: .Normal) btn1.frame = CGRectMake(0, 0, 30, 30) btn1.addTarget(self, action: Selector("action1:"), forControlEvents: .TouchUpInside) let item1 = UIBarButtonItem() item1.customView = btn1 let btn2 = UIButton() btn2.setImage(UIImage(named: "img2"), forState: .Normal) btn2.frame = CGRectMake(0, 0, 30, 30) btn2.addTarget(self, action: Selector("action2:"), forControlEvents: .TouchUpInside) let item2 = UIBarButtonItem() item2.customView = btn2 self.navigationItem.rightBarButtonItems = [item1,item2]
используя
setLeftBarButtonItem
илиsetRightBarButtonItem
let btn1 = UIButton() btn1.setImage(UIImage(named: "img1"), forState: .Normal) btn1.frame = CGRectMake(0, 0, 30, 30) btn1.addTarget(self, action: Selector("action1:"), forControlEvents: .TouchUpInside) self.navigationItem.setLeftBarButtonItem(UIBarButtonItem(customView: btn1), animated: true);
для swift > = 2.2 действие должно быть
#selector(Class.MethodName)
... например,btnName.addTarget(self, action: #selector(Class.MethodName), forControlEvents: .TouchUpInside)
только настройки
UIBarButtonItem
С customViewнапример:
var leftNavBarButton = UIBarButtonItem(customView:yourButton) self.navigationItem.leftBarButtonItem = leftNavBarButton
или использовать
setFunction
:self.navigationItem.setLeftBarButtonItem(UIBarButtonItem(customView: yourButton), animated: true);
Я просто наткнулся на этот вопрос, и вот обновление для Swift 3 и iOS 10:
let testUIBarButtonItem = UIBarButtonItem(image: UIImage(named: "test.png"), style: .plain, target: self, action: nil) self.navigationItem.rightBarButtonItem = testUIBarButtonItem
это определенно намного быстрее, чем создание UIButton со всеми свойствами, а затем последующее добавление customView в UIBarButtonItem.
и если вы хотите изменить цвет изображения с синего по умолчанию на белый, вы всегда можете изменить цвет оттенка:
test.tintColor = UIColor.white()
PS вы, очевидно, должны изменить селектор и т. д. для вашего приложения :)
в swift 3 для действия в кнопке панели:
let testUIBarButtonItem = UIBarButtonItem(image: UIImage(named: "test.png"), style: .plain, target: self, action: #selector(ViewController.clickButton)) self.navigationItem.rightBarButtonItem = testUIBarButtonItem func clickButton(){ print("button click") }
У меня такая же проблема, и я прочитал ответы в другой теме, тогда я решаю другой аналогичный способ. Я не знаю, что более эффективно. аналогичная проблема
//play button @IBAction func startIt(sender: AnyObject) { startThrough(); }; //play button func startThrough() { timer = NSTimer.scheduledTimerWithTimeInterval(1, target: self, selector: Selector("updateTime"), userInfo: nil, repeats: true); let pauseButton = UIBarButtonItem(barButtonSystemItem: .Pause, target: self, action: "pauseIt"); self.toolBarIt.items?.removeLast(); self.toolBarIt.items?.append( pauseButton ); } func pauseIt() { timer.invalidate(); let play = UIBarButtonItem(barButtonSystemItem: .Play, target: self, action: "startThrough"); self.toolBarIt.items?.removeLast(); self.toolBarIt.items?.append( play ); }
установка LeftBarButton с оригинальным изображением.
let menuButton = UIBarButtonItem(image: UIImage(named: "imagename").withRenderingMode(.alwaysOriginal), style: .plain, target: self, action: #selector(classname.functionname)) self.navigationItem.leftBarButtonItem = menuButton
это гораздо проще с
Swift 4
внутри
ViewDidLoad
метод, определите свою кнопку и добавьте ее в панель навигации.override func viewDidLoad() { super.viewDidLoad() let logoutBarButtonItem = UIBarButtonItem(title: "Logout", style: .done, target: self, action: #selector(logoutUser)) self.navigationItem.rightBarButtonItem = logoutBarButtonItem }
затем вам нужно определить функцию, которую вы упомянули внутри параметра действия, как показано ниже
@objc func logoutUser(){ print("clicked") }
вам нужно добавить
@objc
префикс, поскольку он все еще использует устаревшие вещи (цель C).
func viewDidLoad(){ let homeBtn: UIButton = UIButton(type: UIButtonType.custom) homeBtn.setImage(UIImage(named: "Home.png"), for: []) homeBtn.addTarget(self, action: #selector(homeAction), for: UIControlEvents.touchUpInside) homeBtn.frame = CGRect(x: 0, y: 0, width: 30, height: 30) let homeButton = UIBarButtonItem(customView: homeBtn) let backBtn: UIButton = UIButton(type: UIButtonType.custom) backBtn.setImage(UIImage(named: "back.png"), for: []) backBtn.addTarget(self, action: #selector(backAction), for: UIControlEvents.touchUpInside) backBtn.frame = CGRect(x: -10, y: 0, width: 30, height: 30) let backButton = UIBarButtonItem(customView: backBtn) self.navigationItem.setLeftBarButtonItems([backButton,homeButton], animated: true) } }