【Swift UI】ナビゲーションバーのタイトル色を変更する方法!toolbarColorScheme
この記事からわかること
- SwiftUIのNavigationStackで実装したナビゲーションバーのタイトル色を変更するには?
- toolbarColorSchemeモディファイアの使い方
index
[open]
\ アプリをリリースしました /
友達や家族の誕生日をメモ!通知も届く-みんなの誕生日-
posted withアプリーチ
ナビゲーションバーのタイトル色を変更する方法
SwiftUIで以下のようなNavigationStackで実装しているナビゲーションバーのタイトルの色を変更するにはtoolbarColorScheme
モディファイアを使用します。ですがこれはColorScheme
を設定しているので自由に色を指定しているわけではないので注意してください。
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
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
(中央配置)を指定します。
NavigationStack{
Text("MainView")
.toolbar {
ToolbarItem(placement: .principal) {
Text("Navigation Title")
.foregroundColor(.cyan)
.font(.system(size: 18))
}
}
}
この方法であればViewとして扱えるのでカラーだけでなく、文字サイズや余白など自由にカスタマイズすることが可能になります。
まだまだ勉強中ですので間違っている点や至らぬ点がありましたら教えていただけると助かります。
ご覧いただきありがとうございました。