SwiftUI 半高底部modal

  • Xcode 12.5.2
  • iOS 14

参考链接

可点击mask关闭,拖动关闭。详情看动图吧
preview演示

实现

//
//  HalfModel.swift
//  Marking (iOS)
//
//  Created by jc_xcode on 2021/7/25.
//

import SwiftUI

struct Handle : View {
    private let handleThickness = CGFloat(5.0)
    var body: some View {
        RoundedRectangle(cornerRadius: handleThickness / 2.0)
            .frame(width: 40, height: handleThickness)
            .foregroundColor(Color.secondary)
            .padding(5)
    }
}

struct HalfModel<Content: View>: View {
    @State var dragY = UIScreen.main.bounds.height / 2
    @Binding var show: Bool
    var content: () -> Content
    var body: some View {
        let maxHeight = UIScreen.main.bounds.height
        ZStack {
            if show {
                Color.black.opacity(0.3)
                    .edgesIgnoringSafeArea(.all)
                    .onTapGesture {
                        show = false
                    }.onAppear(perform: {
                        print("appear")
                        dragY = maxHeight / 2
                    })
            }
            
            VStack {
                Handle()
                self.content()
                // 如果content是Picker类控件会和drag产生冲突,加上下面这句就不会了
                	.onTapGesture {}
            }.background(Color.white)
            .cornerRadius(10.0)
            .shadow(color: Color(.sRGBLinear, white: 0, opacity: 0.13), radius: 10.0)
            .offset(y: show ? dragY : maxHeight)
            .animation(.interpolatingSpring(stiffness: 300.0, damping: 30.0, initialVelocity: 10.0))
            .gesture(
                DragGesture()
                    .onChanged({
                        dragY = $0.location.y
                    })
                    .onEnded({_ in
                        if dragY > maxHeight * 0.7 {
                            dragY = maxHeight
                            show = false
                        } else {
                            dragY = maxHeight / 2
                        }
                    })
            )
            
        }
    }
}

使用方法

import SwiftUI

struct ModalViewTest: View {
    @State private var show = true
    var body: some View {
        ZStack {
            Color.yellow

            Button(action: {
                show = true
            }, label: {
                Text("show: \(String(show))")
            })
            HalfModel(show: $show) {
                TextEditor(text: .constant("Placeholder"))
            }
        }.edgesIgnoringSafeArea(.all)
    }
}

struct ModalViewTest_Previews: PreviewProvider {
    static var previews: some View {
        ModalViewTest()
    }
}

直接用了 UIScreen.main.bounds.height 来获取屏幕高度,用 GeometryReader 也行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【课程特点】1、231节大容量课程:包含了SwiftUI的大部分知识点,详细讲解SwiftUI的方方面面;2、15个超级精彩的实例:包含美食、理财、健身、教育、电子商务等各行业的App实例;3、创新的教学模式:手把手教您SwiftUI用户界面开发技术,一看就懂,一学就会;4、贴心的操作提示:让您的眼睛始终处于操作的焦点位置,不用再满屏找光标;5、语言简洁精练:瞄准问题的核心所在,减少对思维的干扰,并节省您宝贵的时间;6、视频短小精悍:即方便于您的学习和记忆,也方便日后对功能的检索;7、齐全的学习资料:提供所有课程的源码,在Xcode 11 + iOS 13环境下测试通过; 更好的应用,更少的代码!SwiftUI是苹果主推的下一代用户界面搭建技术,具有声明式语法、实时生成界面预览等特性,可以为苹果手机、苹果平板、苹果电脑、苹果电视、苹果手表五个平台搭建统一的用户界面。SwiftUI是一种创新、简单的iOS开发中的界面布局方案,可以通过Swift语言的强大功能,在所有的Apple平台上快速构建用户界面。 仅使用一组工具和API为任何Apple设备构建用户界面。SwiftUI具有易于阅读和自然编写的声明式Swift语法,可与新的Xcode设计工具无缝协作,使您的代码和设计**同步。自动支持动态类型、暗黑模式、本地化和可访问性,意味着您的**行SwiftUI代码已经是您编写过的非常强大的UI代码了。 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值