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

Hub*_*ski 3 animation button swift swiftui

我有一个播放/暂停按钮,按下时会发生变化。目前它只是淡入淡出,但我希望它执行一个动画,看起来新颜色流过旧颜色。 在此输入图像描述

在此输入图像描述

在此输入图像描述

在此输入图像描述

这是我到目前为止所拥有的:

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)
}
Run Code Online (Sandbox Code Playgroud)

变化meditationViewModel.timerIsRunning发生在其他地方。

Asp*_*eri 5

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

使用 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)
        }
    }
}
Run Code Online (Sandbox Code Playgroud)