13
12

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

iOS 15でSwiftUIビューを定期的にリロードします

Last updated at Posted at 2021-11-26

iOS 15のSwiftUI 3では、新しいビュー構造TimeLineViewがあります。このビュータイプを使って、(あなたが定義した)一定期間ごとにビューをリロードすることができます。

例えば、アニメーションのロード画面を作ることができます。

ezgif-2-554a1eb56133.gif

Thoughts

SwiftUIビューはデータの変更時にだけリロードされるのがベストだと思います。

TimelineViewは、既定のリロード時間が設定されたビューを表示するように設計されているのではないかと思います(例えば、WidgetKitは所定のスケジュールに従ってリロードされます)

実装

public init(_ schedule: Schedule, @ViewBuilder content: @escaping (TimelineView<Schedule, Content>.Context) -> Content)

コードクロージャに渡された変数Contextがあります。この変数を使って、ビューがリロードされた時間にアクセスすることができます。

import SwiftUI

struct ContentView: View {
    var body: some View {
        TimelineView(.periodic(from: Date(), by: 1)) { context in
            Text("\(context.date)")
        }
    }
}

アニメーション付きローディング画面の作成

1秒ごとに画面をリロードできるため、日付から現在の秒の値を読み取り、その値を使用して別の画面を表示することができます。

0、1、2を繰り返すシーケンス番号を生成することができ、その値を使用して別の画面を表示することができます。

let sequenceNo = Calendar.current.component(.second, from: context.date) % 3
struct ContentView: View {
    
    var body: some View {
        Form {
            
            TimelineView(.periodic(from: Date(), by: 1)) { context in
                
                // A number that's in range 0, 1, 2
                let sequenceNo = Calendar.current.component(.second, from: context.date) % 3
                
                HStack {
                    
                    Image(systemName: "gamecontroller")
                        .font(.largeTitle)
                    
                    Image(systemName: "chevron.right")
                        .font(.largeTitle)
                        .foregroundColor((sequenceNo >= 0) ? .green : .init(UIColor.label))
                    
                    Image(systemName: "chevron.right")
                        .font(.largeTitle)
                        .foregroundColor((sequenceNo >= 1) ? .green : .init(UIColor.label))
                    
                    Image(systemName: "chevron.right")
                        .font(.largeTitle)
                        .foregroundColor((sequenceNo >= 2) ? .green : .init(UIColor.label))
                    
                    Image(systemName: "network")
                        .font(.largeTitle)
                        .symbolRenderingMode(.multicolor)
                    
                }
                
            }
            
            Text("Connecting your console to the Internet...")
            
        }
    }
    
}

関連記事

SwiftUIのビューは自動的に再描画され、通常は特定の関数をコールして再読み込みさせることはできません。どの変数を監視させるかをSwiftUIのビューに知らせるには、次の変数型を使用できます。

変数が変更されたときにSwiftUIのViewがリロードされるようにする


:relaxed: Twitter @MszPro

:newspaper: iOS開発に関するニュースレター iOS Dev Letter

:sunny: 私の公開されているQiita記事のリストをカテゴリー別にご覧いただけます。

13
12
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
13
12

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?