今回はViewを重ねて表示できる「ZStack」について解説します。
SwiftUIでViewを重ねて表示する方法【ZStackの使い方】
まずはイニシャライザーです。
ZStack(alignment: Alignment, content: () -> _)
alignment: Alignment は上に重なるViewが従うべきアラインメントを指定します。左上(.topLeading)・右上(.topTrailing)・左下(.bottomLeading)・右下(.bottomTrailing)を指定することができるのが HStack・VStack と異なるところです。
content: () -> _ には重ねて表示するViewを定義します。下記のように外側に {} を置いて定義するのが一般的です。
ZStack(alignment: .leading) {
Rectangle()
Rectangle()
}
シンプルな例(中央寄せ)
Viewを中央寄せに重ねる例です。わかりやすいように色とサイズを変えています。
ZStack {
Rectangle().foregroundColor(.red).frame(width: 300, height: 300)
Rectangle().foregroundColor(.green).frame(width: 200, height: 200)
Rectangle().foregroundColor(.blue).frame(width: 100, height: 100)
}
data:image/s3,"s3://crabby-images/df1ae/df1ae7e5e267796f47e0e7808b7279fb92d79df3" alt=""
左寄せに重ねる
ZStack(alignment: .leading) {
Rectangle().foregroundColor(.red).frame(width: 300, height: 300)
Rectangle().foregroundColor(.green).frame(width: 200, height: 200)
Rectangle().foregroundColor(.blue).frame(width: 100, height: 100)
}
data:image/s3,"s3://crabby-images/d4765/d4765c0671540fef3cad41514ac553eca29038cf" alt=""
右下寄せに重ねる
ZStack(alignment: .bottomTrailing) {
Rectangle().foregroundColor(.red).frame(width: 300, height: 300)
Rectangle().foregroundColor(.green).frame(width: 200, height: 200)
Rectangle().foregroundColor(.blue).frame(width: 100, height: 100)
}
data:image/s3,"s3://crabby-images/7e538/7e5388c5b1e0413bf7c8665b5a33cb06a476c599" alt=""
ZStackの入れ子
ZStack(alignment: .topTrailing) {
Rectangle().foregroundColor(.red).frame(width: 300, height: 300)
ZStack(alignment: .bottomLeading) {
Rectangle().foregroundColor(.green).frame(width: 200, height: 200)
ZStack(alignment: .topLeading) {
Rectangle().foregroundColor(.blue).frame(width: 100, height: 100)
Rectangle().foregroundColor(.yellow).frame(width: 50, height: 50)
}
}
}
data:image/s3,"s3://crabby-images/db9b7/db9b7d093de0af573bb4f300e4044e24a0d4b75e" alt=""
以上
コメントを残す