首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SwiftUI预览中的暗模式在Xcode11.4中没有黑色背景

SwiftUI预览中的暗模式在Xcode11.4中没有黑色背景
EN

Stack Overflow用户
提问于 2020-03-29 17:19:12
回答 3查看 1.2K关注 0票数 6

有没有人有同样的问题,当在黑暗模式下预览时,Xcode (11.4)不显示黑色背景?

重现步骤:

1)创建一个新项目,一个Single View App

2)在预览中添加.environment-modifier:

代码语言:javascript
复制
Group {
    ContentView()
        .environment(\.colorScheme, .light)
    ContentView()
        .environment(\.colorScheme, .dark)
}

您会得到以下结果:

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-03-29 18:07:57

试试这个:

代码语言:javascript
复制
@available(iOS 13.0, *)
public struct DarkView<Content> : View where Content : View {
    var darkContent: Content
    var on: Bool
    public init(_ on: Bool, @ViewBuilder content: () -> Content) {
        self.darkContent = content()
        self.on = on
    }

    public var body: some View {
        ZStack {
            if on {
                Spacer()
                    .frame(minWidth: 0, maxWidth: .infinity, minHeight: 0, maxHeight: .infinity)
                    .background(Color.black)
                    .edgesIgnoringSafeArea(.all)
                darkContent.frame(minWidth: 0, maxWidth: .infinity, minHeight: 0, maxHeight: .infinity).background(Color.black).colorScheme(.dark)
            } else {
                darkContent
            }
        }
    }
}

@available(iOS 13.0, *)
extension View {
    @available(iOS 13.0, *)
    public func darkModeFix(_ on: Bool = true) -> DarkView<Self> {
        DarkView(on) {
            self
        }
    }
}

然后

代码语言:javascript
复制
yourView()
.environment(\.colorScheme, .dark)
                    .darkModeFix()
票数 -1
EN

Stack Overflow用户

发布于 2020-06-08 12:42:19

不建议在环境中设置\.colorScheme,因此请改用.preferedColorScheme修饰符。例如,

代码语言:javascript
复制
ContentView()
    .preferredColorScheme(.dark)
票数 18
EN

Stack Overflow用户

发布于 2020-09-07 17:37:15

正如m-reza-fsimilar question中提到的,这是Xcode中的一个错误(在此答案发布时,Xcode仍处于活动状态)。

我要补充的是,您可以简单地将previews代码包装在PreviewProvider中的NavigationView中,而不是将实际的previews代码包装在NavigationView中,以获得相同的结果:

代码语言:javascript
复制
struct ContentView_Previews: PreviewProvider {
     Group {
          NavigationView {
               ContentView()
                    .environment(\.colorScheme, .light)
          }

          NavigationView {
               ContentView()
                    .environment(\.colorScheme, .light)
          }
     }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60912203

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档