Updated for Xcode 13.0 beta 2
Image view has the ability to be scaled in different ways, just like the content mode of a
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)
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
.fit, like this:
Image("rome") .resizable() .aspectRatio(contentMode: .fit) .frame(width: 250)
SPONSORED From August 2nd to 8th 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!
Link copied to your pasteboard.