如何解决在 SwiftUI 中全屏显示颜色
我正在尝试全屏显示红色。
如果我使用 edgesIgnoringSafeArea(.all)
,屏幕会自动启用滚动,这是我不想要的。你能告诉我如何在不滚动和不拉伸的情况下在全屏显示红色,因为我将颜色更改为图像。
任何帮助将不胜感激。
示例代码如下。
import SwiftUI
struct PageSetup: View {
@State private var tabSelection = 0
var body: some View {
ZStack {
TabView(selection: $tabSelection) {
ForEach(0..<5) { index in
ZStack {
Color.red
Text("\(index)")
}
}
}
.tabViewStyle(PageTabViewStyle())
.onAppear {
UIScrollView.appearance().bounces = false
}
.tabViewStyle(PageTabViewStyle())
}
}
}
输出
解决方法
如果我正确理解您想要什么,那么您在错误的地方使用了 ZStack
和 Color
。您的 body
应该类似于此代码示例。
struct PageSetup: View {
@State private var tabSelection = 0
var body: some View {
ZStack {
getColorForPage().ignoresSafeArea()
TabView (selection: $tabSelection) {
ForEach(0..<5){ index in
Text("\(index)")
}
}
.tabViewStyle(PageTabViewStyle())
.onAppear {
UIScrollView.appearance().bounces = false
}
}
}
func getColorForPage() -> Color {
if tabSelection == 0 {
return Color.red
} else if tabSelection == 1 {
return Color.blue
} else {
return Color.orange
}
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。