布局
alignmentGuide
var body: some View {
VStack (alignment: .center) {
Color.red
.frame(minWidth: 40, maxWidth: 80, minHeight: 10, maxHeight: 20)
.fixedSize()
Image(systemName: "globe")
.imageScale(.large)
.foregroundColor(.accentColor)
.alignmentGuide(HorizontalAlignment.center) { dimension -> CGFloat in
// 表示Image横坐标这个点与容器对齐
dimension[HorizontalAlignment.center]
}
Text("Hello, world!")
}
.border(Color.blue)
}
.alignmentGuide(HorizontalAlignment.center) { dimension -> CGFloat in
// 表示Image横坐标这个点与容器对齐
dimension[HorizontalAlignment.center]
}
data:image/s3,"s3://crabby-images/55ffa/55ffaf024393521828ed8d327d0c1f724ffbb7f9" alt=""
.alignmentGuide(HorizontalAlignment.center) { dimension -> CGFloat in
// 表示Image横坐标这个点与容器对齐
0
}
data:image/s3,"s3://crabby-images/5d411/5d41179ac067f00d40f822ff9d3538c29f1e4fd2" alt=""
.alignmentGuide(HorizontalAlignment.center) { dimension -> CGFloat in
// 表示Image横坐标这个点与容器对齐
-100
}
data:image/s3,"s3://crabby-images/44322/443229a8e91d0a62c41e0f7c5f2cf514a8f5b663" alt=""
Image 填充
Image(name)
.resizable()
.aspectRatio(contentMode: .fit)
.frame(width: 60, height: 60)
想要改变Image的大小,不能简单的修改frame。而是需要先设置.resizable()
,再设置contentMode .aspectRatio(contentMode: .fit)
,最后设置size .frame(width: 60, height: 60)
HStack
aligment
HStack有两种aligment,一个是HStack初始化的入参,另一个是frame里的入参
HStack {
VStack (alignment: .leading, spacing: 0) {
Text("order Accepted")
.font(.caption)
.foregroundColor(.white)
Text("order Accepted order Accepted")
.font(.caption2)
.foregroundColor(.black.opacity(0.3))
}
.frame(maxWidth: .infinity, alignment: .leading)
.offset(y: 15)
}
HStack初始化入参表示子元素的对齐方式,frame的入参表示子元素相对于HStack的对齐方式
data:image/s3,"s3://crabby-images/26195/26195110a0f8221a25c1c20b9c6e95fce7f6889b" alt=""
变为贪婪型
padding
data:image/s3,"s3://crabby-images/95f4f/95f4f285312a3accf3c59b8f3a9a7880e8cb64c5" alt=""
网友评论