首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SwiftUI:如何调整UIViewRepresentable输出的大小?

SwiftUI:如何调整UIViewRepresentable输出的大小?
EN

Stack Overflow用户
提问于 2020-12-21 18:25:36
回答 1查看 283关注 0票数 2

我尝试在SwiftUI上建立一个基本的实时照片应用程序,并与所选照片的显示作斗争。为此,我尝试为PHLivePhotoView创建UIViewRepresentable:

代码语言:javascript
复制
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
    }
}

在我的主要观点中,我这样称呼它:

代码语言:javascript
复制
if pickerResult.count > 0 {
    LivePhotoView(livephoto: $pickerResult[0])
}

直到我尝试限制视图大小时,它才能正常工作。我想把预览放在一个方形的盒子里,就像这样。

代码语言:javascript
复制
LivePhotoView(livephoto: $pickerResult[0])
    .scaledToFit()
    .frame(width: geo.size.width, height: geo.size.width, alignment: .center)

但是scaledToFit()似乎不起作用,我只有一个裁剪过的图像。预期行为是两个具有保留宽高比的图像和较短边的空白空间。这有可能吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-21 18:28:49

在原始视图和SwiftUI中仅限制一个帧,如

代码语言:javascript
复制
func makeUIView(context: Context) -> PHLivePhotoView {
    let photoView = PHLivePhotoView()
    photoView.contentMode = .scaleAspectFit
    return photoView
}

和(甚至不带) frame修饰符

代码语言:javascript
复制
LivePhotoView(livephoto: $pickerResult[0])
    .frame(width: geo.size.width, height: geo.size.width, alignment: .center)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65391057

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档