标签: easeinout

SwiftUI - 使用 .easeInOut 为 ZStack 中的视图不透明度设置动画

我有一个位于 mapView 顶部的视图(在 ZStack 中),并且希望能够通过将.easeInOut动画修改器应用于视图的不透明度来淡入和淡出绿色的上视图。正如您在 gif 中看到的那样,它很好地淡入但突然消失了。

在此处输入图片说明

如果我删除 mapView 那么一切都很好。如果我用一个简单的替换 mapViewRectangle()那么问题又回来了,所以我相信它与 ZStack 而不是地图有关。有趣的是,我实际上使用的是 Mapbox 而不是 MapKit(为了简单起见,如下面的代码所示)并且淡入淡出/突然消失的行为被逆转了。

import SwiftUI
import MapKit

struct ContentView: View {
    @State private var show = false

    var body: some View {
        VStack {
            ZStack {
                MapView()
                if show {
                    LabelView()
                        .transition(AnyTransition.opacity.animation(.easeInOut(duration: 1.0)))
                }
            }
            Button("Animate") {
                self.show.toggle()
            }.padding(20)
        }
    }
}

struct MapView: UIViewRepresentable {
    func makeUIView(context: Context) -> MKMapView {
        let mapView = MKMapView()
        mapView.mapType = .standard
        return mapView
    }

    func …
Run Code Online (Sandbox Code Playgroud)

animation opacity swiftui zstack easeinout

-2
推荐指数
1
解决办法
1711
查看次数

标签 统计

animation ×1

easeinout ×1

opacity ×1

swiftui ×1

zstack ×1