演示效果
示例代码
底部下载源码可获得附带注释的完整源码,可直接运行调试。
var body: some View {
ZStack {
TabView(selection: $selected) {
ForEach(result.indices, id: \.self) { index in
launchPage(result[index])
.tag(index)
}
}
.tabViewStyle(.page(indexDisplayMode: .never))
.ignoresSafeArea()
HStack(spacing: 6) {
ForEach(0...2, id: \.self) { i in
Circle()
.fill(selected == i ? .black.opacity(0.6) : .gray.opacity(0.75))
.frame(width: 8)
}
}
.offset(y: 360)
}
}
@ViewBuilder
func launchPage(_ item: [String : String]) -> some View {
GeometryReader { proxy in
VStack {
Spacer()
Image(item["icon"]!)
.resizable()
.frame(width: 240, height: 240)
Text(item["title"]!)
.font(.title)
.padding(.bottom, 8)
Text(item["subtitle"]!)
.font(.subheadline)
.padding(.horizontal, 32)
.multilineTextAlignment(.center)
Spacer()
Button {
withAnimation {
var newIndex = selected + 1
if (newIndex == result.count) {
newIndex = 0
}
self.selected = newIndex
}
} label: {
Rectangle()
.fill(Color(item["buttonColor"]!))
.overlay {
Text(item["buttonLabel"]!)
.font(.title3)
.fontWeight(.medium)
.foregroundColor(.white)
}
.frame(height: 48)
.cornerRadius(10)
}
.padding()
Spacer()
}
.frame(maxWidth: .infinity, maxHeight: .infinity)
}
.background(Color(red:0.97, green:0.97, blue:0.97))
}