首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用SwiftUI观察窗口大小调整事件

使用SwiftUI观察窗口大小调整事件
EN

Stack Overflow用户
提问于 2021-02-15 03:42:20
回答 1查看 399关注 0票数 0

我目前有一个这样的LazyVGrid设置:

代码语言:javascript
复制
struct NetworkGrid: View {
    var networks: [Network]
    let columns = [
            GridItem(.flexible()),
            GridItem(.flexible()),
            GridItem(.flexible()),
            GridItem(.flexible())
        ]
    
    var body: some View {
        ScrollView {
            LazyVGrid(columns: columns) {
                ForEach(networks) { network in
                    NetworkCard(network: network)
                }
            }
        }
    }
}

我想根据当前窗口大小设置网格列的数量,即

代码语言:javascript
复制
func windowDidResize(_ notification: Notification) {
    itemWidth = CGFloat(300)
    if window.width <= itemWidth {
        GridItem(.flexible()), GridItem(.flexible())
    } else if window.width <= itemWidth * 2 {
        GridItem(.flexible()), GridItem(.flexible()), GridItem(.flexible())
    } else if window.width <= itemWidth * 3 {
        GridItem(.flexible()), GridItem(.flexible()), GridItem(.flexible()), GridItem(.flexible())
    }
    ...
}

我该如何用SwiftUI实现这样一个观察者呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-15 03:54:19

侦听窗口大小的SwiftUI等效项可能是使用GeometryReader。在您的示例中,您可以读取大小并根据其宽度读数动态决定列:

代码语言:javascript
复制
struct NetworkGrid: View {
    var networks: [Network]
    
    func columnsForWidth(width: CGFloat) -> [GridItem] {
        print("Columns for width: \(width)")
        return Array(repeating: GridItem(.flexible()), count: Int(width) / 100)
    }
    
    var body: some View {
        GeometryReader { geometry in
            ScrollView {
                LazyVGrid(columns: columnsForWidth(width: geometry.size.width)) {
                    ForEach(networks) { network in
                        NetworkCard(network: network)
                    }
                }
            }
        }
    }
}
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66199407

复制
相关文章

相似问题

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