ios - GeometryReader 在 SwiftUI 中占用额外空间

下面的代码是创建一个自定义按钮

import SwiftUI

let skyBlue = Color(red: 75/255, green: 170/255, blue: 193/255)

struct RegisterButtonView: View {
    var body: some View {
        GeometryReader { geo in
            HStack {
                Spacer()

                Text("Register")
                    .foregroundColor(Color(.white))
                    .font(.system(size: geo.size.width / 20))
                    .bold()

                Spacer()
            }
            .frame(width: geo.size.width * 4/9, height: geo.size.height / 7)
            .background(skyBlue)
            .cornerRadius(60)
        }

    }
}

struct RegisterButtonView_Previews: PreviewProvider {
    static var previews: some View {
        RegisterButtonView()
    }
}

但是,整个按钮 View 包含由 GeometryReader 引入的额外空间,因此当我将此 View 放入 Root View 时,无法消除该空间。

最佳答案

您可能需要直接设置 GeoReader 的框架。

    struct RegisterButtonView: View {
var body: some View {
    GeometryReader { geo in
        HStack {
            Spacer()

            Text("Register")
                .foregroundColor(Color(.white))
                .font(.system(size: geo.size.width / 20 * 9 / 4))
                .bold()

            Spacer()
        }
        .frame(width: geo.size.width , height: geo.size.height )
        .background(skyBlue)
        .cornerRadius(60)
    }.frame(width: UIScreen.main.bounds.width * 4/9 , height: UIScreen.main.bounds.height / 7)

}
}

https://stackoverflow.com/questions/60456288/

相关文章:

android-studio - 如何禁用 Android-Studio 3.6 中引入的多预览功能

apache-kafka - max.request.size 和 message.max.byte

json - 将 GeoJSON 文件导入 React-Leaflet

javascript - 调用一次从 API 获取数据

reactjs - 清理本地存储后如何进行重定向?

java - 使用 Jacoco Agent 远程触发 jacoco 执行数据转储

c# - 如果正在使用的 USB COM 端口已被移除,SerialPort.Close() 会卡住

javascript - nuxt layout - 为移动端和桌面端提供不同的布局

git - 撤消 Git 中已推送到远程仓库的特定提交

django - 发出命令时出现静态错误 "python manage.py collectstat