我试图在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
视图上使用首选项键的方式?
答案 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)