【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:)を使用し、表示させる値を渡します。

【Swift UI】ProgressViewの使い方!進行状況を表示しよう!
struct LinearProgressDemoView: View {
    @State  private var progress = 0.5
    var body: some View {
        VStack {
            ProgressView(value: progress)
            Button("Add") { progress += 0.05 }
        }
    }
}

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

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

【Swift UI】ProgressViewの使い方!進行状況を表示しよう!

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

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

progressViewStyleで指定する

プログレスバーのスタイルprogressViewStyleモディファイアを使用して明示的に指定することも可能です。その際はlinearorcircularを指定します。

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

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

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

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

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アプリーチ

Githubにて
iOSアプリのソースコードを公開中!

自作Webアプリ

子育て知識共有サイト-mikata-

子育て知識共有サイト-mikata-

フレームワーク:Laravel/Vue.js

作成の流れQiita「Laravel×Vue.jsを使って初めてWebアプリを自作しました!」

感想:初めて作成したWebアプリです!メールアドレスでの会員登録や質問投稿、回答やコメント、いいねやフォローなどSNSに近い機能を実装してみました。レビューや修正すべきポイントなどを教えていただけると嬉しいです!

New Article

index