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

この記事からわかること

  • SwiftUIKitコードNavigationBarItem実装する方法
  • UIBarButtonItemクラスでのバーボタンの定義方法
  • navigationItemプロパティrightBarButtonItem

index

[open]

\ アプリをリリースしました /

みんなの誕生日

友達や家族の誕生日をメモ!通知も届く-みんなの誕生日-

posted withアプリーチ

SwiftのUIKitでコードからNavigationBarItem(ナビゲーションバーにボタンなど)を実装する方法をまとめていきます。この記事ではUINavigationControllerの使い方は解説していないので以下記事を参考にしてください。

コードからNavigationBarItemを実装する方法

手順はこれだけです。NavigationControllerはStoryboardやコードなどから設置しておきます。

UIBarButtonItemクラス

公式リファレンス: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プロパティ

公式リファレンス: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

まだまだ勉強中ですので間違っている点や至らぬ点がありましたら教えていただけると助かります。

ご覧いただきありがとうございました。

searchbox

スポンサー

ProFile

ame

趣味:読書,プログラミング学習,サイト制作,ブログ

IT嫌いを克服するためにITパスを取得しようと勉強してからサイト制作が趣味に変わりました笑
今はCMSを使わずこのサイトを完全自作でサイト運営中〜

New Article

index