今回はローディング中やダウンロードの進行を表現するProgressViewの使い方について説明します。
環境
- Xcode12.5.1
- 動作はシミュレーターのiPhone12 miniで確認
CircularProgressViewStyle
CircularProgressViewStyleは、通信中などに使うクルクルと回転するものです。引数に文字列を渡すことでラベルを表示できます。
struct ContentView: View {
var body: some View {
ProgressView("Now Loading")
}
}
data:image/s3,"s3://crabby-images/14503/14503edc5082e247a2f960432f55c45fedc70230" alt=""
LinearProgressViewStyle
LinearProgressViewStyleはダウンロードの進行状態を表す際などに使用する棒状のスタイルです。value: には進行具合を渡す変数を、total: は value に対しての最大値を指定します。
(今回はデザインがわかりやすいように、初期値を50.0にしています)
struct ContentView: View {
@State private var current = 50.0
var body: some View {
ProgressView("Now Downloading", value: current, total: 100)
}
}
data:image/s3,"s3://crabby-images/d14b8/d14b832f8da3692091b82d3346284cf158cbf197" alt=""
色の変更
CircularProgressViewStyleはテキストのみ色を変更できます。
struct ContentView: View {
var body: some View {
ProgressView("Now Loading")
.foregroundColor(.green)
}
}
data:image/s3,"s3://crabby-images/d9f15/d9f15a0ab5c90bba7e03d40e635c011ab499f9c0" alt=""
LinearProgressViewStyleはテキストとバーの色を変更できます。
struct ContentView: View {
@State private var current = 50.0
var body: some View {
ProgressView("Now Downloading", value: current, total: 100)
.accentColor(.red)
.foregroundColor(.green)
}
}
data:image/s3,"s3://crabby-images/a025f/a025f9ffd49c03b1a4d829dc4fd257399f9d1b93" alt=""
今回は以上です。
コメント