SwiftUI将两个子视图传递给View

时间:2020-03-23 00:57:44

标签: swift swiftui

我正在尝试使用@ViewBuilder作为视图的子级传递两个视图。

我需要能够知道哪个是第一个,哪个是第二个,因为我想根据某种状态显示一个或另一个。

我能够以一种非通用的方式进行这项工作,这意味着我明确给出了子视图的类型。

struct FlippableView<Content: View>: View {
    @State private var flipped = false
    @State private var degrees = 0.0

    var frontCard: FeedItem
    var backCard: FeedItem

    @inlinable public init(@ViewBuilder content: () -> Content) {
        var t = content() as! TupleView<(FeedItem, FeedItem)>
        self.frontCard = t.value.0
        self.backCard = t.value.1
    }

    var body: some View {
        return Group() {
            if self.degrees < 90 {
                self.frontCard
            } else {
                self.backCard
                    .rotation3DEffect(Angle(degrees: 180), axis: (x: CGFloat(0), y: CGFloat(10), z: CGFloat(0)))

            }
        }
    }

如何通过摆脱FeedItem类型来使其更加通用。我希望这两个视图是两种不同的视图类型。

1 个答案:

答案 0 :(得分:3)

这是可能的变体。使用Xcode 11.4 / iOS 13.4进行了测试

struct FlippableView<V1: View, V2: View>: View {
    @State private var flipped = false
    @State private var degrees = 0.0

    var frontCard: V1
    var backCard: V2

    @inlinable public init(@ViewBuilder content: () -> TupleView<(V1, V2)>) {
        let t = content()
        self.frontCard = t.value.0
        self.backCard = t.value.1
    }

    var body: some View {
        return Group() {
            if self.degrees < 90 {
                self.frontCard
            } else {
                self.backCard
                    .rotation3DEffect(Angle(degrees: 180), axis: (x: CGFloat(0), y: CGFloat(10), z: CGFloat(0)))

            }
        }
    }
}