如何找到SwiftUI UIViewRepresentable的框架

时间:2020-01-03 06:02:46

标签: uikit interop swiftui

我试图在UILabel中包装UIViewRepresentable的自定义子类,以在SwiftUI中使用它。我正在使用.sizeToFit并打印框架,当它在包装器中时看起来正确:

func makeUIView(context: Context) -> CustomUILabel {
    let view = CustomUILabel()
    view.customProperty = model.customProperty
    view.sizeToFit()
    print(model.latex,view.frame.size) // this prints the correct size, how to propagate?
    return view
}

但是当我在VStack中运行它时,它将以最大可能的空间绘制UIViewRepresentable

var body: some View {
    GeometryReader{ geometry in
        VStack(spacing: 0){
            Rectangle()
                .fill(Color.red)
                .frame( height: geometry.size.height/2 - 5 + self.draggedOffset.height)
            Rectangle()
                .fill(Color.orange)
                .frame(height: 10)
            custonView(model:self.model)
            Spacer()
    }
}

是否有一种方法可以将UIView的大小传播到其父级,类似于您在本机SwiftUI视图上使用首选项键的方式?

2 个答案:

答案 0 :(得分:2)

这是由于使用了GeometryReader

尝试使用

custonView(model:self.model)
    .fixedSize()

答案 1 :(得分:0)

使用UIViewRepresentable时,您所描述的贪婪是通过contentHuggingPriority控制的,就像它在UIKit中一样。

因此,在您的makeUIView函数中,您可以这样做:

// resist being made larger than the intrinsicContentSize
view.setContentHuggingPriority(.defaultHigh, for: .horizontal)
view.setContentHuggingPriority(.defaultHigh, for: .vertical)