Image
Imageを表示させるには以下のようにAssetにある文字列を渡してやることで表示することができます
struct ContentView: View {
var body: some View {
Image("sample")
}
}
data:image/s3,"s3://crabby-images/a1e4e/a1e4e3ffdebccbaae9f3fcfa9905ae00e890edf7" alt=""
Resizable
画像の大きさを任意の値にしたい時frameをつけただけでは画像サイズが変更されず画像そのもののサイズで表示されてしまいます。
Image("sample").frame(width: 100, height: 100)
ImageViewのサイズを可変にするにはresizableというView修飾子をつける必要があります
struct ContentView: View {
var body: some View {
Image("sample")
.resizable()
.frame(width: 100, height: 100)
}
}
data:image/s3,"s3://crabby-images/0cb37/0cb3760335cfcf44dfa258d38309bfe7cbcbd5e5" alt=""
AspectRatio
AspectRatioにはfitとfillが存在しfitは縦横の大きい方に合わせて表示、fitは縦横の小さい方に合わせてはみ出さないように表示します。
data:image/s3,"s3://crabby-images/b72e3/b72e333f50f08e7879e25d139e457ac57deece8b" alt=""
struct ContentView: View {
var body: some View {
VStack {
Image("sample")
.resizable()
.aspectRatio(contentMode: .fill)
.frame(width: 50, height: 100)
Image("sample")
.resizable()
.aspectRatio(contentMode: .fit)
.frame(width: 50, height: 100)
}
}
}
RenderingMode
UIKItではボタンに画像を設定する際などによく使用したメソッドだと思いますが動きは同じです。
renderingModeがtemplateでforegroundColorが指定されている時は画像がその色に塗り潰されます。
data:image/s3,"s3://crabby-images/d5327/d5327749a56f62a67ee5c1b692ccacb4032da4e2" alt=""
struct ContentView: View {
var body: some View {
HStack {
Image("sample")
.resizable()
.renderingMode(.template)
.frame(width: 100, height: 100)
Image("sample")
.resizable()
.renderingMode(.template)
.foregroundColor(.pink)
.frame(width: 100, height: 100)
Image("sample")
.resizable()
.renderingMode(.original)
.frame(width: 100, height: 100)
}
}
}