SwiftUI:如何调整 UIViewRepresentable 输出的大小?
SwiftUI: how to resize the UIViewRepresentable output?
我尝试在 SwiftUI 上构建一个基本的 Live Photo 应用程序,但在显示所选照片时遇到了困难。为此,我尝试为 PHLivePhotoView 制作 UIViewRepresentable:
import SwiftUI
import PhotosUI
struct LivePhotoView: UIViewRepresentable {
@Binding var livephoto: PHLivePhoto
func makeUIView(context: Context) -> PHLivePhotoView {
return PHLivePhotoView()
}
func updateUIView(_ lpView: PHLivePhotoView, context: Context) {
lpView.livePhoto = livephoto
}
}
在我的主视图中,我这样称呼它:
if pickerResult.count > 0 {
LivePhotoView(livephoto: $pickerResult[0])
}
在我尝试限制视图大小时之前它工作正常。我想把预览放到一个方框里,有类似的东西
LivePhotoView(livephoto: $pickerResult[0])
.scaledToFit()
.frame(width: geo.size.width, height: geo.size.width, alignment: .center)
但 scaledToFit() 似乎不起作用,我只有裁剪后的图像。预期的行为是两个具有保留宽高比的图像和较短的一侧为空的 space。这甚至可能吗?
在原始视图中执行,在 SwiftUI 中仅限制一个框架,例如
func makeUIView(context: Context) -> PHLivePhotoView {
let photoView = PHLivePhotoView()
photoView.contentMode = .scaleAspectFit
return photoView
}
和(甚至w/o)frame
修饰符
LivePhotoView(livephoto: $pickerResult[0])
.frame(width: geo.size.width, height: geo.size.width, alignment: .center)
我尝试在 SwiftUI 上构建一个基本的 Live Photo 应用程序,但在显示所选照片时遇到了困难。为此,我尝试为 PHLivePhotoView 制作 UIViewRepresentable:
import SwiftUI
import PhotosUI
struct LivePhotoView: UIViewRepresentable {
@Binding var livephoto: PHLivePhoto
func makeUIView(context: Context) -> PHLivePhotoView {
return PHLivePhotoView()
}
func updateUIView(_ lpView: PHLivePhotoView, context: Context) {
lpView.livePhoto = livephoto
}
}
在我的主视图中,我这样称呼它:
if pickerResult.count > 0 {
LivePhotoView(livephoto: $pickerResult[0])
}
在我尝试限制视图大小时之前它工作正常。我想把预览放到一个方框里,有类似的东西
LivePhotoView(livephoto: $pickerResult[0])
.scaledToFit()
.frame(width: geo.size.width, height: geo.size.width, alignment: .center)
但 scaledToFit() 似乎不起作用,我只有裁剪后的图像。预期的行为是两个具有保留宽高比的图像和较短的一侧为空的 space。这甚至可能吗?
在原始视图中执行,在 SwiftUI 中仅限制一个框架,例如
func makeUIView(context: Context) -> PHLivePhotoView {
let photoView = PHLivePhotoView()
photoView.contentMode = .scaleAspectFit
return photoView
}
和(甚至w/o)frame
修饰符
LivePhotoView(livephoto: $pickerResult[0])
.frame(width: geo.size.width, height: geo.size.width, alignment: .center)