7

我怎样才能在列表的中心制作这个箭头?

struct ProductsList : View {
var body: some View {

    VStack {
        List {
            Image(systemName: "shift")


        }

    }
}

}

在此处输入图像描述

4

3 回答 3

15

您可能只想使用一些垫片。

struct ProductsList : View {
    var body: some View {
        VStack {
            List {
                HStack {
                   Spacer()
                   Image(systemName: "shift")
                   Spacer()
                } 
            }
        }
    }
}
于 2019-06-21T01:17:41.107 回答
6

试试这个:

var body: some View {
    List {
        GeometryReader { geometry in
            VStack(alignment: .center) {
                Image(systemName: "shift")
            }.frame(width: geometry.size.width)
        }
    }
}

于 2019-06-20T20:08:16.387 回答
6

我建议使用 ViewModifier:

struct CenterModifier: ViewModifier {
    func body(content: Content) -> some View {
        HStack {
            Spacer()
            content
            Spacer()
        }
    }
} 

因此,在您的列表中,如果您有更多不同类型的 UI 元素,则可以使用更方便的方法:

struct ExampleList: View {
    var body: some View {
        List {
            Image(systemName: "shift").modifier(CenterModifier())
            SomeOtherView().modifier(CenterModifier())
        }
    }
}
于 2020-04-09T07:30:08.977 回答