gpt4 book ai didi

SwiftUI - 调整 ScrollView 滚动指示器插入

转载 作者:行者123 更新时间:2023-12-05 02:02:21 39 4
gpt4 key购买 nike

我正在创建一个聊天应用程序,我希望 ScrollView 的内容位于输入字段下方(向上滚动时)。我已经将 ScrollView 和输入字段放在 ZStack 中。 ScrollView 上的底部填充使内容向上移动,但我也希望滚动指示器随着内容向上移动。

是否有任何方法可以更改滚动指示器的插入以匹配填充,或任何其他解决方法来实现我正在寻找的内容?

这是当前代码:

          ZStack(alignment: .bottom) {
ScrollView {
ScrollViewReader { value in
VStack(spacing: 5) {
ForEach(MOCK_MESSAGES) {
mMessage in
MessageView(mMessage: mMessage)
}
.onAppear {
value.scrollTo(MOCK_MESSAGES.count - 1)
}
}
.padding(.top, 10)
.padding(.bottom, 40)
}
}
MessageInputView(messageText: $messageText)
}

总结:想法是让 ScrollView 位于输入 View 上方,但向上滚动时将内容移动到输入 View 下方。

最佳答案

iOS 15/ swift 3

您可以使用 .safeAreaInset 而不是填充来执行此操作,然后它也会为您处理滚动指示器插入。

ScrollView {
ScrollViewReader { value in
VStack(spacing: 5) {
// stuff
}
}
}
.safeAreaInset(edge: .bottom) {
MessageInputView(messageText: $messageText)
}

注意:从 Xcode 13.1 开始,.safeAreaInsets 似乎不适用于 List

更新:从 iOS 15.2 开始,safeAreaInsets() 也适用于 List 和 Form。

iOS 14/Swift 2 或带列表

与 SwiftUI 中的许多事情一样,如果不修改底层的 UIKit 组件,似乎无法做到这一点。不过有一个简单的解决方案,使用 Introspect图书馆:

ZStack(alignment: .bottom) {
ScrollView {
ScrollViewReader { value in
VStack(spacing: 5) {
// stuff
}
.padding(.top, 10)
.padding(.bottom, 40)
}
}
.introspectScrollView { sv in
sv.verticalScrollIndicatorInsets.top = 10
sv.verticalScrollIndicatorInsets.bottom = 40
}
MessageInputView(messageText: $messageText)
}

您也可以使用带有 introspectTableViewList 来完成。

关于SwiftUI - 调整 ScrollView 滚动指示器插入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65832238/

39 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com