首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SwiftUI用图像包装HStack

SwiftUI用图像包装HStack
EN

Stack Overflow用户
提问于 2021-05-22 13:48:03
回答 1查看 1.3K关注 0票数 2

我正在尝试制作一个包含x个图像的HStack,并以包装HStack的方式显示它们(也就是说,如果7幅图像中只有4幅适合在行上,则将剩下的3幅图像溢出到下一行)。

我正在尝试使用库WrappingHStack (https://github.com/dkk/WrappingHStack),但结果并不像预期的那样,图像没有包装。

这是我的代码:

代码语言:javascript
复制
    @State var numEarths : Int = 7;
    var body: some View {
        VStack{
        
            Text("If everyone were to live like you, we would need \(numEarths) Earths").font(.title)
            WrappingHStack{
                ForEach(0 ..< numEarths){_ in
                Image("logo")
                
                }
             }
         }
    }

这是模拟器上的结果(见,没有包装),...we应该看到7个地球徽标图像,但你只能看到4个(和一点数字5)。图像截图

有人能帮我解决这个问题吗?我是SwiftUI开发的新手,所以如果这是一个愚蠢的错误,请轻率地问我。谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-05-22 15:13:15

根据WrappingHStack库,如果您想实现上述目标,您需要做两件事:

  • Image一个frame,这样WrappingHStack就可以知道每行要放多少个元素。
  • ForEach循环更改为WrappingHStack,因为WrappingHStack可用作对项进行循环的ForEach
代码语言:javascript
复制
WrappingHStack(0..<numEarths, id:\.self) { _ in
    Image("logo")
        .resizable()
        .frame(width: 100, height: 100)
}

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67650216

复制
相关文章

相似问题

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