SwiftUI ScrollView导致视图塌陷(高度为0)问题

在SwiftUI中,如果一个没有固定尺寸的视图放进ScrollView,父视图没有给它明确的尺寸约束,它的高度将被计算为 0。

在显示Lottie动画时,发现计划显示的Lottie动画在Xcode预览中正常显示,但是在模拟器和真机中无法显示。

视图代码:

php 复制代码
LottieView(filename: "EmptyBanklet", isPlaying: true, playCount: 0, isReversed: false)
    .frame(maxHeight: 180)
    .frame(maxWidth: 500)

经过和其他可以显示的Lottie动画对比,并没有发现问题。

但是给该视图添加固定的frame后,Lottie动画可以正常显示:

php 复制代码
LottieView(filename: "EmptyBanklet", isPlaying: true, playCount: 0, isReversed: false)
    .frame(height: 100)
    .frame(maxHeight: 180)
    .frame(maxWidth: 500)

排查过程

起初判定原因是,我设置了忽略安全区域和填充样式的背景,导致图片在顶部显示。但当我设置整个视图为纯色背景时,仍然没有看到竖向填充的背景色。

php 复制代码
LottieView(filename: "EmptyBanklet", isPlaying: true, playCount: 0, isReversed: false)
    .frame(maxHeight: 180)
    .frame(maxWidth: 500)
    .background(Color.red)  // 检查视图

接着,我尝试使用Geometry获取视图的高度:

php 复制代码
GeometryReader { geo in
    LottieView(filename: "EmptyBanklet", isPlaying: true, playCount: 0, isReversed: false)
        .frame(maxHeight: 180)
        .frame(maxWidth: 500)
        .onAppear {
            print("SwiftUI 给 LottieView 的尺寸:", geo.size)
        }
}

Xcode输出:

scss 复制代码
SwiftUI 给 LottieView 的尺寸: (300.0, 10.0)

这表示SwiftUI给视图很小的高度,并且可以在视图中看到很小的LottieView动画。

当我删除GeometryReader后,LottieView再次消失。因此,开始怀疑LottieView动画过小导致的问题。

在LottieView代码中调试并打印UIKit尺寸:

javascript 复制代码
DispatchQueue.main.asyncAfter(deadline: .now() + 0.1) {
    print("UIKit Lottie frame:", animationView.frame)
}

Xcode输出:

objectivec 复制代码
UIKit Lottie frame: (0.0, 0.0, 300.0, 0.0)

这表示视图的高度为0,因此看不到LottieView动画。

但是这个问题,在欢迎视图和设置视图的LottieView中并不能复现,因为欢迎视图和设置视图中的LottieView都是正常显示的,也就是说这个问题在这个视图中。

我通过排查法,将Lottie视图依次放在父视图中。经过层层排查,发现当LottieView视图放到ScrollView中后,视图塌陷(高度变为0)。

解决方案

因为这里的主要问题在于,ScrollView中的LottieView视图高度变成了0。

可以设置一个固定的高度,让LottieView视图显示出来:

php 复制代码
LottieView(filename: "EmptyBanklet", isPlaying: true, playCount: 0, isReversed: false)
    .frame(maxHeight: 100)
    .frame(maxHeight: 180)
    .frame(maxWidth: 500)

还有一个解决方案,那就是我想到类似的问题比较像Image图片,Image图片也是需要拉伸显示。

可以设置LottieView视图为 .scaledToFit(),这个方法可以在不设置固定高度的情况下,显示完整的视图大小。

php 复制代码
LottieView(filename: "EmptyBanklet", isPlaying: true, playCount: 0, isReversed: false)
    .scaledToFit()
    .frame(maxHeight: 180)
    .frame(maxWidth: 500)

因此,使用 .scaledToFit() 方法的方案更合适,可以解决ScrollView中视图塌陷(高度为0)的问题。

相关推荐
wjm0410062 小时前
ios内存管理
ios·objective-c·swift·客户端开发
黑科技iOS上架2 小时前
ios应用被封号后再次上架很难么?
经验分享·ios
柚鸥ASO优化7 小时前
一篇讲透安卓ASO!开发者千万别只盯着iOS了
android·ios·aso优化
黑科技iOS上架7 小时前
Swift Package Manager包管理工具的优缺点
经验分享·ios
大熊猫侯佩11 小时前
Swift 6.4 的 Ref / MutableRef 大揭秘:给值类型开一扇“安全的小窗”
ios·swift·编程语言
黑科技iOS上架12 小时前
没有mac电脑如何借助windows系统上传ipa到App Store
经验分享·ios
Layer13 小时前
从 WWDC 26 空间重构(Spatial Reframing)再看端侧 2D 转 3D 的技术演进
ios·aigc
Cutecat_1 天前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
大熊猫侯佩1 天前
WWDC26 SwiftUI 进化之路:砸碎黑盒,彻底迎来开发自由!
ios·swiftui·swift
游戏开发爱好者81 天前
iPhone真机调试有哪些方法?一次定位推送权限问题时整理出来的几种方案
ide·vscode·ios·objective-c·个人开发·swift·敏捷流程