【Swift UI】ナビゲーションバーのタイトル色を変更する方法!toolbarColorScheme

この記事からわかること

  • SwiftUINavigationStack実装したナビゲーションバータイトル色変更するには?
  • toolbarColorSchemeモディファイア使い方

index

[open]

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

みんなの誕生日

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

posted withアプリーチ

ナビゲーションバーのタイトル色を変更する方法

SwiftUIで以下のようなNavigationStackで実装しているナビゲーションバーのタイトルの色を変更するにはtoolbarColorSchemeモディファイアを使用します。ですがこれはColorSchemeを設定しているので自由に色を指定しているわけではないので注意してください。

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

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

上記の場合はdarkを指定しているので文字色が白色になります。明示的に黒色にしたい場合は以下のようにlightを指定します。

.toolbarColorScheme(.light)

toolbarColorScheme

toolbarColorScheme

func toolbarColorScheme(
    _ colorScheme: ColorScheme?,
    for bars: ToolbarPlacement...
) -> some View

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

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

}

指定できるのは列挙型ColorSchemeに定義されている値です。

public enum ColorScheme : CaseIterable {
    case light // 通常モード
    case dark // ダークモード
}

自由に色を変更する

タイトルのカラーをforegroundColorモディファイアを使用して自由に指定するにはtoolbarモディファイアを使用してナビゲーションタイトルを自前で実装する必要があります。

toolbarモディファイアにToolbarItem構造体を渡しprincipal(中央配置)を指定します。

【Swift UI】ナビゲーションバーのタイトルフォントやサイズを変更する方法
NavigationStack{
    Text("MainView")
        .toolbar {
            ToolbarItem(placement: .principal) {
                Text("Navigation Title")
                    .foregroundColor(.cyan)
                    .font(.system(size: 18))
            }
        }
}

この方法であればViewとして扱えるのでカラーだけでなく、文字サイズや余白など自由にカスタマイズすることが可能になります。

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

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

searchbox

スポンサー

ProFile

ame

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

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

New Article

index