当系统外观更改时,SwiftUI ButtonStyle 动画会导致应用程序切换器快照中的 UI 不更新

Jor*_*n H 3 ios swift swiftui ios-darkmode swiftui-14.2-defect

在我的应用程序中,我有一个按钮,我想在触摸它时以动画方式缩小。为此,我创建了一个ButtonStyle具有显式animation. 这按预期工作,但在暗/亮模式系统外观之间切换时引入了问题。如果您在应用程序打开时更改它,Color则会按预期更新,但如果应用程序未打开,应用程序切换器中的快照将显示新系统外观的错误颜色。以下代码在浅色模式下应该是白色背景上的黑框,在深色模式下应该是黑底白字。背景始终会正确更新,但方框在快照中仍保持旧颜色,因此您无法看到它 - 黑底黑字或白底白字 - 至少从 iOS 14.2 开始是这样。问题是animation- 如果我删除快照,则会按预期显示。这是为什么?我该如何解决它?

struct ContentView: View {
    var body: some View {
        Button(action: {}) {
            Color.primary
                .frame(height: 100)
        }
        .buttonStyle(MyButtonStyle())
        .padding()
    }
}

struct MyButtonStyle: ButtonStyle {
    func makeBody(configuration: Self.Configuration) -> some View {
        configuration.label
            .scaleEffect(configuration.isPressed ? 0.8 : 1)
            .animation(.easeOut(duration: 0.5)) //FIXME: Removing this fixes it
    }
}
Run Code Online (Sandbox Code Playgroud)

在这里,我在浅色模式下运行应用程序,然后关闭它,启用深色模式,然后打开应用程序切换器,发现该框在黑色背景上是黑色的。该框应该是白色的,就像我点击应用程序将其返回前台时一样。

截图

Asp*_*eri 10

在 iOS 14.1 上运行良好,所以我认为这是 14.2 的另一个缺陷。

尝试将动画链接到值(未经测试,只是想法):

struct MyButtonStyle: ButtonStyle {
    func makeBody(configuration: Self.Configuration) -> some View {
        configuration.label
            .scaleEffect(configuration.isPressed ? 0.8 : 1)
            .animation(.easeOut(duration: 0.5), value: configuration.isPressed)
    }
}
Run Code Online (Sandbox Code Playgroud)