【Swift UIKit】コードでNavigationBarItemを実装する方法と使い方

この記事からわかること
- SwiftのUIKitでコードでNavigationBarItemを実装する方法
- UIBarButtonItemクラスでのバーボタンの定義方法
- navigationItemプロパティのrightBarButtonItem
index
[open]
\ アプリをリリースしました /
SwiftのUIKitでコードからNavigationBarItem(ナビゲーションバーにボタンなど)を実装する方法をまとめていきます。この記事ではUINavigationControllerの使い方は解説していないので以下記事を参考にしてください。
コードからNavigationBarItemを実装する方法
- NavigationControllerを設置
- UIBarButtonItemを定義
- navigationItemプロパティに格納
手順はこれだけです。NavigationControllerはStoryboardやコードなどから設置しておきます。
UIBarButtonItemクラス
コードからナビゲーションバーにあるボタンを実装するにはまずUIBarButtonItem
クラスのボタンを定義します。イニシャライザを使用することで文字列や画像などをボタンとして配置することができます。
文字列
convenience init(
title: String?,
style: UIBarButtonItem.Style,
target: Any?,
action: Selector?
)
画像
convenience init(
image: UIImage?,
style: UIBarButtonItem.Style,
target: Any?,
action: Selector?
)
let barButton = UIBarButtonItem(image: UIImage(systemName: "checkmark"), style:.plain, target: self, action: nil)
バーボタンの定義は通常のUIButtonのようにターゲットとアクションを紐付けることができます。
navigationItemプロパティ
ボタンを定義したらUIViewController
の持つnavigationItem
プロパティの持つrightBarButtonItem
などに指定します。これでナビゲーションバー部分に反映されるようになります。
let barButton = UIBarButtonItem(image: UIImage(systemName: "checkmark"), style:.plain, target: self, action: nil)
self.navigationItem.rightBarButtonItem = barButton
let leftButton = UIBarButtonItem(image: UIImage(systemName: "chevron.backward"), style:.plain, target: self, action: nil)
self.navigationItem.leftBarButtonItem = leftButton
おすすめ記事:【Swift UIKit】遷移後の画面から戻る方法!dismissとNavigationController
まだまだ勉強中ですので間違っている点や至らぬ点がありましたら教えていただけると助かります。
ご覧いただきありがとうございました。
個人開発に限界を感じたらiOSに特化したプログラミングスクール「iOSアカデミア」も検討してみてください!無料相談可能で「最短・最速」でiOSエンジニアになれるように手助けしてくれます。