TabView
Skip support for SwiftUI.TabView on Android. Consult the SkipUI module for a complete list of supported SwiftUI.
The following example screens and source code is from SkipUI’s
Showcase sample app
TabViewPlayground.swift
data:image/s3,"s3://crabby-images/97f22/97f22c430433010c7bf7d1b1d32e10845f2c728c" alt="Android screenshot for TabView component (light mode)"
data:image/s3,"s3://crabby-images/defe6/defe6ebaeec76cf8fbd43edf36d860be25448816" alt="iPhone screenshot for TabView component (light mode)"
data:image/s3,"s3://crabby-images/64b0c/64b0c635f61321a4205e3fcbdb40be6f9d18d22e" alt="iPhone screenshot for TabView component (dark mode)"
data:image/s3,"s3://crabby-images/2e7de/2e7de4d508805ba8fa3c1b52b41eaf75fccb3327" alt="Android screenshot for TabView component (dark mode)"
import SwiftUI
struct TabViewPlayground: View {
@State var selectedTab = "Home"
var body: some View {
TabView(selection: $selectedTab) {
TabPlaygroundContentView(label: "Home", selectedTab: $selectedTab)
.tabItem { Label("Home", systemImage: "house.fill") }
.tag("Home")
TabPlaygroundContentView(label: "Favorites", selectedTab: $selectedTab)
.tabItem { Label("Favorites", systemImage: "heart.fill") }
.tag("Favorites")
TabPlaygroundContentView(label: "Info", selectedTab: $selectedTab)
.tabItem { Label("Info", systemImage: "info.circle.fill") }
.tag("Info")
}
.toolbar {
PlaygroundSourceLink(file: "TabViewPlayground.swift")
}
}
}
struct TabPlaygroundContentView: View {
let label: String
@Binding var selectedTab: String
var body: some View {
VStack {
Text(label).bold()
if label != "Home" {
Button("Switch to Home") {
selectedTab = "Home"
}
}
if label != "Favorites" {
Button("Switch to Favorites") {
selectedTab = "Favorites"
}
}
if label != "Info" {
Button("Switch to Info") {
selectedTab = "Info"
}
}
}
}
}