【Swift UI】ProgressViewで進行状況表示!色や大きさと使い方

この記事からわかること

  • Swift UIProgressViewタスク進行状況表示させる方法
  • プログレスバーローディングビュー、パーセンテージ
  • サイズ変更方法
  • progressViewStyle円形にする

index

[open]

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

みんなの誕生日

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

posted withアプリーチ

ProgressView構造体

公式リファレンス:ProgressView構造体

Swift UIのProgressView構造体を使用することでタスクの進行状況を表示するプログレスバーやローディングビューを簡単に構築することができます。

struct ProgressView<Label, CurrentValueLabel> where Label : View, CurrentValueLabel : View

プログレスバーを表示する

プログレスバーを表示させるためにはProgressView(value:)を使用し引数value表示させる値を渡します。あとはその値を変化させることでプログレスバーが変化していきます。

【Swift UI】ProgressViewで進行状況表示!色や大きさと使い方
struct ContentView: View {
    @State  private var progress = 0.5
    var body: some View {
        VStack {
            ProgressView(value: progress)
            Button("Add") { progress += 0.05 }
        }
    }
}

ローディングビューを表示する

円形でインジケーターがぐるぐるするようなローディングビューを実装したい場合はProgressViewに引数なしでインスタンス化するだけです。

【Swift UI】ProgressViewで進行状況表示!色や大きさと使い方
struct ContentView: View {
    var body: some View {
        VStack {
            ProgressView()
        }
    }
}

例えばAsyncImageなどでサーバーの画像を表示させるなど少し時間のかかる処理を実装する場合はそのプレースホルダーとして以下のようなローディングビューを設置すると見た目がよくなります。

これは引数なしでそのまま記述すればOKです。

AsyncImage(url: URL(string: "https://appdev-room.com/image/swift.png")) { image in
  image.resizable()
} placeholder: {
  ProgressView()
}.frame(width: 50, height: 50)

progressViewStyleで指定する

プログレスバーのスタイルprogressViewStyle(_: ProgressViewStyle)モディファイアを使用して明示的に指定することも可能です。その際はProgressViewStyle型であるlinearまたはcircularを指定します。

struct ContentView: View {
    @State  private var progress = 0.6

    var body: some View {
        VStack {
            ProgressView(value: progress)
                .progressViewStyle(.linear)
            ProgressView()
                .progressViewStyle(.circular)
        }
    }
}

インジケータの色を変更する

インジケータの色を変更したい場合progressViewStyleの引数に渡すProgressViewStyle型のイニシャライザinit(tint: Color)に色を渡すだけです。

【Swift UI】ProgressViewで進行状況表示!色や大きさと使い方
ProgressView(value: progress)
    .progressViewStyle(LinearProgressViewStyle(tint: .orange))
Button("Add") { progress += 0.05 }
    .padding()

ProgressView()
    .progressViewStyle(CircularProgressViewStyle(tint: .orange))

サイズを変更する

ローディングビューのサイズを変更したい場合scaleEffectを使用して拡大させることで実現できます。

【Swift UI】ProgressViewで進行状況表示!色や大きさと使い方
ProgressView()
    .progressViewStyle(CircularProgressViewStyle(tint: .orange))
    .scaleEffect(3)

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

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

searchbox

スポンサー

ProFile

ame

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

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

New Article

index