ahe*_*eze 6 uiscrollview ios swift swiftui
我正在努力让我的ScrollView:
这是我的代码:
struct ContentView: View {
    init() {
        UIScrollView.appearance().alwaysBounceVertical = false
    }
    var body: some View {
        ScrollView {
            Rectangle()
                .fill(Color.blue)
                .frame(height: 300) /// is smaller than the screen
                .padding()
        }
    }
}
我尝试设置UIScrollView.appearance().alwaysBounceVertical = false,但滚动视图仍然弹跳:
 
如果我这样做UIScrollView.appearance().bounces = false,它就会停止弹跳。但是,如果我使矩形比屏幕高,它也会停止弹跳(这是我不想要的)。
如何禁用弹跳,但仅当内容小于滚动视图的边界时?
对于 iOS 16.4+,请参阅@JuvinR 的回答
嗯,使用时SwiftUI-Introspect,设置alwaysBounceVertical为false确实有效。我不太确定为什么像你那样设置外观不起作用......
无论如何,这里是一些工作示例代码:
struct ContentView: View {
    
    @State private var count = 5
    
    var body: some View {
        VStack {
            Picker("Count", selection: $count) {
                Text("5").tag(5)
                Text("100").tag(100)
            }
            .pickerStyle(SegmentedPickerStyle())
            
            ScrollView {
                VStack {
                    ForEach(1 ... count, id: \.self) { i in
                        Text("Item: \(i)")
                    }
                }
                .frame(maxWidth: .infinity)
            }
            .introspectScrollView { scrollView in
                scrollView.alwaysBounceVertical = false
            }
        }
    }
}
结果(不幸的是,你看不到我的鼠标试图拖动较短的列表):
小智 6
从iOS 16.4开始,有一个新的callback修饰符.scrollBounceBehavior,可以用来防止ScrollView在内容小于屏幕时弹起。
例子:
struct ContentView: View {
    
    var body: some View {
        ScrollView {
            Rectangle()
                .fill(Color.blue)
                .frame(height: 300)
                .padding()
        }
        .scrollBounceBehavior(.basedOnSize)
    }
    
}
| 归档时间: | 
 | 
| 查看次数: | 5359 次 | 
| 最近记录: |