Picker
Skip support for SwiftUI.Picker 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
PickerPlayground.swift
data:image/s3,"s3://crabby-images/bbfe4/bbfe4ee173351d49cdfc21a71cc1c9aab6b738ad" alt="Android screenshot for Picker component (light mode)"
data:image/s3,"s3://crabby-images/b92a2/b92a29bcaad62fa947aeb8eae0deee81eba6c36b" alt="iPhone screenshot for Picker component (light mode)"
data:image/s3,"s3://crabby-images/15d34/15d342d75e9774f26c4f7e159d99ecd62de5e113" alt="iPhone screenshot for Picker component (dark mode)"
data:image/s3,"s3://crabby-images/cb248/cb24836012cf7681ccc72035cdd5b37e4a2b3fb4" alt="Android screenshot for Picker component (dark mode)"
import SwiftUI
struct PickerPlayground: View {
let values = ["One", "Two", "Three", "Four", "Five"]
@State var selectedValue = "Two"
var body: some View {
ScrollView {
VStack(spacing: 16.0) {
Text("Note: Picker displays differently when in a Form. See the Form playground")
.font(.caption)
VStack {
Text("Viewbuilder init")
Picker(selection: $selectedValue) {
ForEach(values, id: \.self) {
Text($0)
}
} label: {
Text("Label")
}
}
VStack {
Text("String init")
Picker("Label", selection: $selectedValue) {
ForEach(values, id: \.self) {
Text($0)
}
}
}
VStack {
Text(".disabled(true)")
Picker("Label", selection: $selectedValue) {
ForEach(values, id: \.self) {
Text($0)
}
}
.disabled(true)
}
VStack {
Text(".foregroundStyle(.red)")
Picker("Label", selection: $selectedValue) {
ForEach(values, id: \.self) {
Text($0)
}
}
.foregroundStyle(.red)
}
VStack {
Text(".tint(.red)")
Picker("Label", selection: $selectedValue) {
ForEach(values, id: \.self) {
Text($0)
}
}
.tint(.red)
}
VStack {
Text("Label")
Picker("Label", selection: $selectedValue) {
ForEach(values, id: \.self) {
Label($0, systemImage: "heart.fill")
}
}
}
VStack {
Text("Fixed content")
Picker("Label", selection: $selectedValue) {
Text(verbatim: values[0]).tag(values[0])
Text(verbatim: values[1]).tag(values[1])
Text(verbatim: values[2]).tag(values[2])
Text(verbatim: values[3]).tag(values[3])
Text(verbatim: values[4]).tag(values[4])
}
}
VStack {
Text("Indexed ForEach")
Picker("Label", selection: $selectedValue) {
ForEach(0..<5) { index in
Text(verbatim: values[index]).tag(values[index])
}
}
}
#if os(macOS)
#else
Picker(".pickerStyle(.navigationLink)", selection: $selectedValue) {
ForEach(values, id: \.self) {
Text($0)
}
}
.pickerStyle(.navigationLink)
Picker("Label .navigationLink", selection: $selectedValue) {
ForEach(values, id: \.self) {
Label($0, systemImage: "heart.fill")
}
}
.pickerStyle(.navigationLink)
#endif
}
.padding()
}
.toolbar {
PlaygroundSourceLink(file: "TogglePlayground.swift")
}
}
}