2

我尝试在 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() 似乎不起作用,我所拥有的只是一张裁剪的图像。预期的行为是两个具有保留纵横比的图像和较短边的空白空间。这甚至可能吗?

4

1 回答 1

3

在原始视图中执行此操作,并且在 SwiftUI 中仅限制一个框架,例如

func makeUIView(context: Context) -> PHLivePhotoView {
    let photoView = PHLivePhotoView()
    photoView.contentMode = .scaleAspectFit
    return photoView
}

和(甚至没有)frame修饰符

LivePhotoView(livephoto: $pickerResult[0])
    .frame(width: geo.size.width, height: geo.size.width, alignment: .center)
于 2020-12-21T10:28:49.003 回答