偏移不会在onTapGesture之后重置-SwiftUI

时间:2020-07-21 10:38:07

标签: ios swift animation swiftui

我正在尝试创建一张在轻按时会滑动的卡,然后返回到原始位置而无需再次点击 点按手势的.onEnded()函数不起作用

这是测试代码

struct ContentView: View {

@State var tapped = false
var body: some View {
    VStack {
        ZStack {
            Rectangle()
                .fill(Color.green)
                .frame(height: 300)
            
            Rectangle()
                .fill(Color.red)
                .frame(width: 290, height: 64)
                .offset(y: tapped ? 118 : 0)
                .onTapGesture {
                    self.tapped.toggle()
            }
            .animation(.easeInOut)
        }
        
        Spacer()
    }.edgesIgnoringSafeArea(.all)
}

}

1 个答案:

答案 0 :(得分:2)

应用的属性不会自行神奇地重置-您需要在需要时更改它们。

这是最简单的解决方案。使用Xcode 11.4 / iOS 13.4进行了测试

demo

var body: some View {
    VStack {
        ZStack {
            Rectangle()
                .fill(Color.green)
                .frame(height: 300)

            Rectangle()
                .fill(Color.red)
                .frame(width: 290, height: 64)
                .offset(y: tapped ? 118 : 0)
                .onTapGesture {
                    self.tapped.toggle()
                    DispatchQueue.main.asyncAfter(deadline: .now() + 0.5) {
                        self.tapped.toggle()
                    }
            }
            .animation(Animation.easeInOut(duration: 0.5))
        }

        Spacer()
    }.edgesIgnoringSafeArea(.all)
}