Updated for Xcode 13.0
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 Join a FREE crash course for iOS devs who want to become complete senior developers — from October 18th to 24th. Learn how to apply iOS app architecture patterns through a series of lectures and practical coding sessions.
Link copied to your pasteboard.