ScrollView + LazyStacks 口吃

问题描述 投票:0回答:1

在使用 ScrollView

LazyVStack
/
LazyHStack
时,我遇到了许多与
this
类似的问题,其中惰性堆栈的内容在
ScrollView
边缘弹跳时会出现卡顿。

首先,我认为这可能是由于在惰性堆栈上使用复杂的视图,这会导致 SwiftUI 中的布局问题,但我设法想出了一个使用非常简单的视图层次结构的 MWE,但问题仍然存在。

这会导致快速向左滚动以及在

ScrollView
的前缘弹跳时出现卡顿:

ScrollView(.horizontal) {
    LazyHStack {
        Color.red.frame(width: 450)
        Color.green.frame(width: 250)
        Color.blue.frame(width: 250)
    }
}
.frame(width: 350)

减小第一个视图的宽度可以消除卡顿现象

ScrollView(.horizontal) {
    LazyHStack {
        Color.red.frame(width: 400) //<- No stutter
        Color.green.frame(width: 250)
        Color.blue.frame(width: 250)
    }
}
.frame(width: 350)

对于这个 MWE,口吃似乎只发生在设备上(可能是因为我在模拟器中滚动得不够快)。然而,我在具有更复杂视图的模拟器中也遇到了同样的问题。

如果这是 SwiftUI 中的错误,有什么想法吗?

在 iPhone Xs Max 上使用 Xcode 13 beta 1 和 iOS 15 进行测试。

swiftui scrollview bounce lazyvstack
1个回答
0
投票

闪烁问题:我有:VStack > HStack > ScrollView > VStack > 添加所有 LazyVStack 自定义视图的循环

通过以下方式修复了闪烁问题:VStack > HStack > ScrollView > VStack > 循环添加包含每个自定义视图的 ScrollView(因此每个自定义 LazyVStack 视图都位于其自己的 ScrollView 内)

我并不是说我理解这一点,我只是说它对我有用!

© www.soinside.com 2019 - 2024. All rights reserved.