【Swift UI】ナビゲーションバーの背景色を変更する方法!toolbarBackground

この記事からわかること

  • SwiftUINavigationStack実装したナビゲーションバー背景色変更するには?
  • toolbarBackgroundモディファイア使い方
  • toolbarBackground(_ visibility:for:) toolbarBackground(_ style:for:)違い

index

[open]

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

みんなの誕生日

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

posted withアプリーチ

参考文献:How to change a navigation bar color in SwiftUI on iOS 16

ナビゲーションバーの背景色を変更する方法

SwiftUIで以下のようなNavigationStackで実装しているナビゲーションバーの背景色を変更するにはtoolbarBackgroundモディファイアを使用します。引数には変更したいカラー変更したツールバーの場所(今回はnavigationBar)を渡します。

【Swift UI】ナビゲーションバーの背景色を変更する方法!toolbarBackground
struct TestNavigationView: View {
    
    var body: some View {
        NavigationStack {
            List {
                NavigationLink("MyNextViewへ") {
                    MyNextView()
                }
            }.navigationTitle("TestNavigationView")
                .toolbarBackground(Color.orange,for: .navigationBar)
        }
    }
}

struct MyNextView: View {
    var body: some View {
        Text("MyNextView")
    }
}

これで画面を下にスクロールした際に上に表示されるナビゲーションバーの背景を変化させることができます。しかしこの方法ではList構造体を使用した場合など、画面をスクロールした場合のみ適応されるようになっています。

常時カラーを適応させる

スクロール時ではなく、常時背景色を変更させたい場合はtoolbarBackgroundの引数に.visibleを渡します。

【Swift UI】ナビゲーションバーの背景色を変更する方法!toolbarBackground
struct TestNavigationView: View {
    var body: some View {
        NavigationStack {
            List {
                NavigationLink("MyNextViewへ") {
                    MyNextView()
                }
            }.navigationTitle("TestNavigationView")
                .toolbarBackground(Color.orange,for: .navigationBar)
        }
    }
}

toolbarBackgroundモディファイア

toolbarBackgroundSwiftUIによって管理されているバーの背景に関する設定を指定できるメソッドです。ナビゲーションバーだけでなく、タブバーやボトムバーなどToolbarPlacement構造体で定義されている値の範囲に適応されます。

struct ToolbarPlacement {
  static var automatic: ToolbarPlacement
  static var bottomBar: ToolbarPlacement
  static var navigationBar: ToolbarPlacement
  static var tabBar: ToolbarPlacement
  static var windowToolbar: ToolbarPlacement

}

toolbarBackgroundメソッドは同名の引数違いで2つ用意されています。

toolbarBackground(_ style:for:)

公式リファレンス:toolbarBackground

func toolbarBackground<S>(
    _ style: S,
    for bars: ToolbarPlacement...
) -> some View where S : ShapeStyle

toolbarBackground(_ style:for:)背景の優先形状スタイルを指定します。スタイルとして渡すのはShapeStyleプロトコルに準拠した値であり、Color構造体も適合しています。なのでそのまま色味を指定すればOKです。

toolbarBackground(_ visibility:for:)

公式リファレンス:toolbarBackground

func toolbarBackground(
    _ visibility: Visibility,
    for bars: ToolbarPlacement...
) -> some View

toolbarBackground(_ visibility:for:)背景の優先可視性を指定します。列挙型Visibilityで定義されている値を渡すことで、表示/非表示を切り替える役割があります。

enum Visibility {
  case automatic
  case hidden
  case visible
}

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

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

searchbox

スポンサー

ProFile

ame

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

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

自作iOSアプリ

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

mapping

自分だけの地図を作ろう!-mapping-

無料posted withアプリーチ

割り勘アプリ-bill-

旅行におすすめ!
割り勘アプリ-bill-

無料posted withアプリーチ

Imakoko

現在地を取得するアプリ!Imakoko

無料posted withアプリーチ

ふるログ

ふるさと納税管理アプリ-ふるログ-

無料posted withアプリーチ

Remind-シンプル通知アプリ-

シンプル通知アプリ-Remind-

無料posted withアプリーチ

CLIPURL

好きな記事をクリップしよう!-CLIPURL-

無料posted withアプリーチ

記録カレンダー

続けたを可視化できるアプリ!記録カレンダー

無料posted withアプリーチ

CART-共有できるお買い物リスト-

CART-共有できるお買い物リスト-

無料posted withアプリーチ

QuickPressPanel

早押しゲーム-QuickPressPanel-

無料posted withアプリーチ

貸し借り管理アプリ

友達とのお金の管理-貸し借り管理アプリ-

無料posted withアプリーチ

みんなの誕生日

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

posted withアプリーチ

Githubにて
iOSアプリのソースコードを公開中!

自作Webアプリ

子育て知識共有サイト-mikata-

子育て知識共有サイト-mikata-

New Article

index