【Swift UI】アプリ内でダークモードとライトモードを切り替える方法!

この記事からわかること

  • SwiftUIアプリ内からダークモード/ライトモード切り替える方法
  • ColorSchemeとは?
  • preferredColorScheme使い方

index

[open]

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

みんなの誕生日

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

posted withアプリーチ

Swift UIでアプリ内からダークモードとライトモードを切り替えられるようにする機能を実装する方法をまとめていきます。

アプリ内からダークモードとライトモードを切り替える方法

iPhoneではユーザーの設定でダークモードとライトモードが装備されており、設定によって画面の色味が変化します。アプリ内でもユーザー設定によって背景色や文字色などが自動で切り替わるようになっています。

アプリ内のデザインも大きく変化するのでそれぞれに対応したデザインで作成する必要があります。

デバイスの設定ではなくアプリ内からダークモード/ライトモードの切り替え(アプリ内デザインのみ)を行えるような仕組みを作っていきたいと思います。

ポイント

ColorSchemeとはユーザーが設定しているモードの値が定義されている列挙型です。

public enum ColorScheme : CaseIterable {
    case light // ライトモード
    case dark // ダークモード
}

おすすめ記事:ColorSchemeとは?

preferredColorSchemeメソッド

ビューに対してダークモード/ライトモードを指定するのはpreferredColorSchemeメソッドを使用します。引数にColorSchemeの値を指定します。

このメソッドが呼び出されたビューを囲むビューまで含めて指定されたモードへ変更されます。例えば以下の場合、呼び出しているのはText構造体からですが画面全体がダークモードへと変更されます。もちろん子ビューにもこの設定は伝播していきます。

struct ContentView: View {
    var body: some View {
            Text("Test").preferredColorScheme(.dark)
    }
}

実装してみる

あとはifや文や?:などを使用して引数として渡すモード値を変更させればアプリ内からビューに対してモードの切り替えが可能になります。

struct ContentView: View {
    @State  private var isDarkMode = true
    var body: some View {
        Button(action: {
            isDarkMode.toggle()
        }, label: {
            Text(isDarkMode ? "Light Mode" : "Dark Mode")
        }).preferredColorScheme(isDarkMode ? .dark : .light)
    }
}
【Swift UI】アプリ内でダークモードとライトモードを切り替える方法!

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

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

私がSwift UI学習に使用した参考書

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