Updated for Xcode 14.2
SwiftUI’s Image
view has the ability to be scaled in different ways, just like the content mode of a UIImageView
.
By default, image views automatically size themselves to their contents, which might make them go beyond the screen. If you add the resizable()
modifier then the image will instead automatically be sized so that it fills all the available space, either in a frame you specify or whatever is available on the screen:
Image("rome")
.resizable()
.frame(height: 200)
Download this as an Xcode project
However, that may also cause the image to have its original aspect ratio distorted, because it will be stretched in all dimensions by whatever amount is needed to make it fill the space.
If you want to keep its aspect ratio you should add an aspectRatio
modifier using either .fill
or .fit
, like this:
Image("rome")
.resizable()
.aspectRatio(contentMode: .fit)
.frame(width: 250)
Download this as an Xcode project
SPONSORED From March 20th to 26th, you can join a FREE crash course for mid/senior iOS devs who want to achieve an expert level of technical and practical skills – it’s the fast track to being a complete senior developer!
Sponsor Hacking with Swift and reach the world's largest Swift community!
Link copied to your pasteboard.