SwiftUIコンポーネントのまとめ
これは、SwiftUI
のビュー要素のコレクションです。
URL: https://SwiftUI.MszPro.com
@MszPro
個人アプリ開発の最新情報、
iOSプログラミングやSwiftUIに関する記事、
美しい写真やアニメの絵などを掲載しています
ぜひフォローをお願いします。
🐘 マストドン @[email protected]
Bluesky @mszpro.com
Twitter @MszPro
[ サイト ] https://MszPro.com
data:image/s3,"s3://crabby-images/d525a/d525a585b588a43d0b089630b8a7c19e2dfe4baf" alt=""
Updates
Latest update: 2024-02-11
⚡️このページでは、
より多くのビューモディファイアの例を更新中です。
キャッシュの関係で、手動で再読み込みボタンをクリックして、最新版を読み込んでください。
☺️しばらくお待ちください。
文字
画像
画面に複数の要素を表示
上記ビューの複数を1つのビューに組み合わせて表示できます。
フォーム入力
TextField (.axis) |
SecureField |
TextEditor |
複数行のテキストフィールド |
パスワード入力用 |
長い文字列を表示して編集 |
data:image/s3,"s3://crabby-images/deb2a/deb2aeb72f51f1d749c8469d0964e9d958835cd2" alt="image" |
data:image/s3,"s3://crabby-images/cd9c4/cd9c4ed22a6cdfb92720c5c8ac52b0a349a10f1b" alt="image" |
data:image/s3,"s3://crabby-images/485bb/485bb3ee38b4f2246c4c1b49e793aa491f6c8ba4" alt="image" |
コード例を見る |
コード例を見る |
コード例を見る |
>= iOS 16 |
- |
|
ピッカー / 選択
ColorPicker |
DatePicker |
MultiDatePicker |
色を選択できるようにします。 |
日付を選択します |
複数日付選択ツール |
data:image/s3,"s3://crabby-images/22378/22378d2cfa75a17cca8d0551924bf219376befed" alt="image" |
data:image/s3,"s3://crabby-images/d7517/d7517ae7e0966c93accf94f8bdecf6752ecff20b" alt="image" |
data:image/s3,"s3://crabby-images/2023a/2023a543a00528e8be304adfb4854eed27134aa2" alt="image" |
コード例を見る |
コード例を見る |
コード例を見る |
- |
- |
> iOS 16 |
表
ナビゲート
NavigationStack |
NavigationSplitView |
ナビゲーションを追加する |
サイドバーメニューを含むナビゲーションを追加する |
data:image/s3,"s3://crabby-images/df1c5/df1c5245109e2b51da9b57359b70ae4418df5739" alt="image" |
data:image/s3,"s3://crabby-images/c671c/c671cabf1353ac0db0ffaa57c11c328be4514b52" alt="image" |
コード例を見る |
コード例を見る |
>= iOS 16 |
>= iOS 16 |
NavigationView |
ナビゲーションビュー内に自前のViewを埋め込み |
data:image/s3,"s3://crabby-images/df1c5/df1c5245109e2b51da9b57359b70ae4418df5739" alt="image" |
コード例を見る |
DEPRECATED 廃止された < iOS 16 |
アクションを実行するには/ユーザーに別のビューを表示するには
タブビュー
地図
チャート
Qiita記事
WWDC22、iOS 16:SwiftUIでChartsフレームワークを使ってチャートを作成
Chart + PointMark |
Chart + LineMark + PointMark |
Chart + BarMark |
ポイント チャート |
折れ線グラフ |
棒グラフ |
data:image/s3,"s3://crabby-images/4b3dd/4b3ddb1509b5c44de18e8881f9eab7726086f94d" alt="image" |
data:image/s3,"s3://crabby-images/7e754/7e75410c1764dae80694b41920c9b25f3534043f" alt="image" |
data:image/s3,"s3://crabby-images/923ca/923ca0c76db516aebd380666a9d54c2be6930ac2" alt="image" |
コード例を見る |
コード例を見る |
コード例を見る |
>= iOS 16 |
>= iOS 16 |
>= iOS 16 |
Chart + AreaMark + LineMark |
Charts with multiple data set |
面グラフ |
1つのグラフの中に複数のデータを表示することができます。例えば、2ヶ所の天気を比較することができます。 |
data:image/s3,"s3://crabby-images/dbd40/dbd400cbda7a57fb9388bf3a09e6f4e2da132890" alt="image" |
data:image/s3,"s3://crabby-images/78743/7874379e0d07f9b3a3de57271ceb507a591f58a6" alt="image" |
コード例を見る |
コード例を見る |
>= iOS 16 |
>= iOS 16 |
レイアウト
DisclosureGroup |
GroupBox |
コンテンツを表示および非表示 |
角丸のボックス内にタイトルとコンテンツビューを表示 |
data:image/s3,"s3://crabby-images/cdc2a/cdc2a937417b8d25432701dc0920a3db769f02ff" alt="image" |
data:image/s3,"s3://crabby-images/51242/5124254f6862dfb6c16f14a279e00ab4b378eed7" alt="image" |
コード例を見る |
コード例を見る |
ScrollView(.horizontal) |
ScrollView(.verticle) |
水平方向にスクロールできるようにする |
縦方向にスクロールできるようにする |
data:image/s3,"s3://crabby-images/76c08/76c082cf9bfa46c8271d216a65883e7aaeb1117c" alt="image" |
data:image/s3,"s3://crabby-images/65402/65402a7a70ebb832ca42543b98c1a5aafa154285" alt="image" |
コード例を見る |
コード例を見る |
アラート / アクションシート
進捗状況を表示するビュー
Features
Sign in with Apple |
PhotosPicker |
ShareLink |
Appleでサインイン |
写真選択ツール |
共有シート |
data:image/s3,"s3://crabby-images/25fbd/25fbdac3af90edb61e9099e8e227f6e86b5890a6" alt="image" |
data:image/s3,"s3://crabby-images/b11b5/b11b5bb73d78a858d90d397fbec9322c1a9a90e3" alt="image" |
data:image/s3,"s3://crabby-images/0d9e2/0d9e2d418c383d6a8e406070d97cce3ba3c117ee" alt="image" |
コード例を見る |
コード例を見る |
コード例を見る |
- |
>= iOS 16 |
>= iOS 16 |
PasteButton |
ペーストボードからデータ(画像など)を読み込む |
data:image/s3,"s3://crabby-images/6e444/6e4448dd0dc1b35a5772a2142880a9be61e1627a" alt="image" |
コード例を見る |
>= iOS 16 |
UIKit + SwiftUI
UIHostingController
UIHostingControllerを使用して、UIKitビュー内にSwiftUIビューを表示することも可能です。
let swiftuiView = Map_Example()
let uiKitViewController = UIHostingController(rootView: swiftuiView)
self.present(uiKitViewController, animated: true, completion: nil)
UIViewControllerRepresentable
こちらのコード例は、SwiftUICompatible
と呼ばれるフレームワークを使用しています。
SwiftUICompatible
へアクセスするにはこちらをクリックしてください。
SwiftUI は新しいフレームワークであるので、フィーチャー UIKit の幾らかを欠いています。そららフィーチャー UIKit を活用する為には、UIViewControllerRepresentable を使用しなければなりません。
TextMessageComposerView |
SafariView |
DocumentPicker |
テキストメッセージコンポーザー |
ウェブ表示 |
ドキュメントピッカー |
|
data:image/s3,"s3://crabby-images/d087d/d087d57cf8c08f68e693b3845039ec451cc3d7ce" alt="image" |
data:image/s3,"s3://crabby-images/e405b/e405b6fe81ec48786080f41e279034f32651bd61" alt="image" |
|
|
|
コード例を見る |
コード例を見る |
コード例を見る |
UIViewRepresentable
SwiftUIでUIKitの UIView を互換性のあるものにするために、
UIViewRepresentableを使用することにします。
QRCodeScanner |
SwiftUIのビューでQRコードを読み取る |
data:image/s3,"s3://crabby-images/a415c/a415c4a79f934278b2f969d34e85223116c281e8" alt="image" |
コード例を見る |
私が公開したSwiftUIに関するの記事
https://qiita.com/search?q=user%3AMaShunzhe%20tag%3ASwiftUI&sort=created
SwiftUI ビューの基本フォーマット
SwiftUI ビューの基本構造は次のとおり:
import SwiftUI
struct TextField_Example: View {
// 変数
var body: some View {
//UIコンポーネント
//Text, Image, Form, VStack, List, ...
}
}
var body: some View
セクションで、ビューコードを入力。
このWebページで提供されているサンプルコードでは、body
コードブロック内のコンテンツに注意を払う必要がある。
// 変数
セクションで、変数を宣言する。
変数の型
お気づきになられたかもしれませんが、SwiftUI
にはいくつもの型の変数があります。最もよく使われている変数の型2つを以下でご紹介します。
@State
struct ButtonSheet_Example: View {
@State var showAnotherView: Bool = false
var body: some View {
Button(action: {
self.showAnotherView = true
}, label: {
Text("別のビューを表示")
})
.sheet(isPresented: $showAnotherView, content: {
AnotherView(textContent: "Hello World.")
})
}
}
@State
の値を変更することで、ビューの見た目に影響を与えることができます。
例えば、もしプログラムのどこかで showAnotherView
が true
に設定されていれば、ビュー AnotherView
が表示されます。
プログラムの中で @State
変数を使う時は、変数名の前に $
記号を付け加える必要があるかもしれません。そうすることで、ビューにその変数を監視(および変数が変更されればビューのコンテンツを更新)させることができます。
@State
変数の値を次の3つの方法で初期化できます:
@State var showAnotherView: Bool = false
- ビュー
ButtonSheet_Example
を初期化すると、変数を初期化できます。 ButtonSheet_Example(showAnotherView: true)
init
関数の中で変数を初期化できます:
struct ButtonSheet_Example: View {
@State var showAnotherView: Bool
init(...) {
self.showAnotherView = .init(initialValue: false)
}
var body: some View {
// TODO
}
}
変数 (var)
変数は値を格納するために利用されます。変数を更新してもプログラムの見た目に影響はありません。
struct ButtonSheet_Example: View {
var userTappedButton: () -> Void
var body: some View {
Button(action: {
self.userTappedButton()
}, label: {
Text("別のビューを表示")
})
}
}
プレビュー
XcodeではSwiftUIファイルに加えた変更を直接プレビューすることができます。プレビューは以下のように宣言します。
struct TextField_Example_Previews: PreviewProvider {
static var previews: some View {
TextField_Example(textEntered: "SwiftUI_Components-Library")
}
}
static var previews: some View
内で、SwiftUI表示を初期化していただけます。Xコードの右側にある Resume
ボタンをクリックするとプレビューが表示されます。
⭐️
Mastodon @[email protected]
Twitter @MszPro
個人ウェブサイト
:sunny: 私の公開されている記事をカテゴリー別にご覧いただけます:
data:image/s3,"s3://crabby-images/d525a/d525a585b588a43d0b089630b8a7c19e2dfe4baf" alt=""
data:image/s3,"s3://crabby-images/92a04/92a04dd3e8d6c568d55503ed9597fb9945f9afc5" alt="writing-quickly_emoji_400.png"