今回はTabViewの使い方について説明します。非常に簡単なので説明するまでもないかもですが…
環境
- Xcode12.5.1
- 動作はシミュレーターのiPhone12 miniで確認
基本的な使い方
基本的には以下のような実装方法になります。
TabViewのクロージャの中に各ページの内容を書いていき、モディファイアでタブに表示するボタンの内容を実装します。
今回はタブ内の内容をテキストだけにしていますが、もちろん自作のstructを表示することも可能です。
struct ContentView: View {
var body: some View {
TabView{
Text("ページ1")
.tabItem {
Text("ページ1")
}
Text("ページ2")
.tabItem {
Text("ページ2")
}
}
}
}
data:image/s3,"s3://crabby-images/92810/928107d576fdeff928716f397568681737564723" alt=""
TabItemのカスタマイズ
lineやfacebookのタブのように、アイコンと文字の両方を表示することも簡単です。
struct ContentView: View {
var body: some View {
TabView{
Text("ホーム")
.tabItem {
Image(systemName: "house")
Text("ホーム")
}
Text("メッセージ")
.tabItem {
Image(systemName: "message")
Text("メッセージ")
}
Text("タイムライン")
.tabItem {
Image(systemName: "clock")
Text("タイムライン")
}
Text("設定")
.tabItem {
Image(systemName: "slider.horizontal.3")
Text("設定")
}
}
}
}
data:image/s3,"s3://crabby-images/3083d/3083d286a4ee08948c51b39ed64af8f9a952aba3" alt=""
表示できるTabItemは5コまで
以下のようにタブをたくさん追加すると、5つ目以降はMoreと書かれたボタンが表示され省略されます。
struct ContentView: View {
var body: some View {
TabView{
Text("ホーム")
.tabItem {
Image(systemName: "house")
Text("ホーム")
}
Text("メッセージ")
.tabItem {
Image(systemName: "message")
Text("メッセージ")
}
Text("タイムライン")
.tabItem {
Image(systemName: "clock")
Text("タイムライン")
}
Text("設定")
.tabItem {
Image(systemName: "slider.horizontal.3")
Text("設定")
}
Text("ホーム")
.tabItem {
Image(systemName: "house")
Text("ホーム")
}
Text("メッセージ")
.tabItem {
Image(systemName: "message")
Text("メッセージ")
}
Text("タイムライン")
.tabItem {
Image(systemName: "clock")
Text("タイムライン")
}
Text("設定")
.tabItem {
Image(systemName: "slider.horizontal.3")
Text("設定")
}
}
}
}
data:image/s3,"s3://crabby-images/b9447/b9447987e63a373d11a3a5b2b84c07bcfbfbed93" alt=""
Moreをタップすると省略されたアイテムがList表示されます。
data:image/s3,"s3://crabby-images/95721/957216b866ef47ddf415e58c368301ff8fe1c962" alt=""
ちなみに右上のEditを押すと、以下のような画面が表示され、タブに表示するアイテムをカスタマイズできます。
data:image/s3,"s3://crabby-images/40d9b/40d9bf99329fdf0bd5bbba878852791153876695" alt=""
説明に書いてある通り、ドラッグで入れ替えることができます。
data:image/s3,"s3://crabby-images/89372/89372691c4fc55a6421a8f981c25ab7154b3724a" alt=""
コメント