站点图标 Codeun

SwiftUI 首次启动引导页示例代码、点击or滑动展示下一页

SwiftUI 首次启动引导页示例代码、点击or滑动展示下一页
Guide Launch 启动引导页示例

演示效果

示例代码

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))
    }

源码下载

退出移动版