如何使用 swiftUI 创建平滑的颜色变化动画? (有问题的例子)

How can I create a smooth colour change animation using swiftUI? (Example in question)

我有一个 play/pause 按钮,按下时会发生变化。目前它只是淡入和淡出,但我希望它执行一个动画,看起来新颜色流过旧颜色。

这是我目前拥有的:

if(meditationViewModel.timerIsRunning){
    HStack{
        Image(systemName: "pause")
        Text("STOP")
            .bold()
     }
      .padding()
      .foregroundColor(.white)
      .background(Color.red)
      .cornerRadius(25)
      .shadow(radius: 20)
}else{
    HStack{
        Image(systemName: "play")
        Text("PLAY")
            .bold()
    }
     .padding()
     .foregroundColor(.white)
     .background(Color.green)
     .cornerRadius(25)
}

meditationViewModel.timerIsRunning 的变化发生在别处。

这是一个可能的方法演示 - 只需在文本和不透明背景之间使用一些形状(在本例中为圆形)并根据状态移动它。

准备 Xcode 12.4 / iOS 14.4

注意:您可以只使用点按手势而不是按钮并调整所有参数和颜色,但总的来说,想法保持不变

struct DemoView: View {
    @State private var playing = false
    var body: some View {
        Button(action: { playing.toggle() }) {
            HStack{
                Image(systemName: playing ? "pause" : "play")
                Text(playing ? "STOP" : "PLAY")
                    .bold()
            }
            .background(
                Circle().fill(Color.purple)
                    .frame(width: 160, height: 160, alignment: .leading)
                    .blur(radius: 3)
                    .offset(x: playing ? 0 : -160, y: -40)
                    .animation(.easeInOut(duration: 1), value: playing)
            )
            .padding()
            .foregroundColor(.white)
            .background(Color.green)
            .cornerRadius(25)
            .clipped()
            .shadow(radius: 20)
        }
    }
}