Getting Started
Scale effect allows you to scale a SwiftUI view.
Note: The view may become pixelated if scaled up.
Using Scale Effect
A scale of less than 1.0 will scale the view down, while a scale greater than 1.0 will scale the view up. The scaleEffect
modifier can be attached to any SwiftUI view.
In the following example, a value of 0.5 is supplied as the scale.
data:image/s3,"s3://crabby-images/a50d4/a50d45f8926d3162ecde7a0d4bc98a720212ff1f" alt=""
Likewise, when the scale is above 1.0, the view scales up.
data:image/s3,"s3://crabby-images/6fecf/6fecf21fb265a50f627e6765642470a0d67d335b" alt=""
Scaling by Axis
There are 2 approaches to scaling by axis. You can use CGSize
or directly supply the X and Y values.
The two examples below produce the same results.
data:image/s3,"s3://crabby-images/092ba/092bab0548d6c8b1517985d7b5f73f0d97be931f" alt=""
This works the same in the Y axis / height.
data:image/s3,"s3://crabby-images/c49e9/c49e94810417593269b99cd66334bb3be549ad87" alt=""
When using the .scaleEffect(x: …, y: …)
implementation, the x
and y
values can be omitted if the intended scale is 1.
Scaling and Layout
Important Note: The View's frame does not change when it is scaled.
Notice how, in the following example, the red border is around the "original frame" of the View. This may cause unexpected behaviour when laying out views, especially when embedding inside a HStack and VStack. If a View is scaled up, the scaled View may overlap onto other surrounding views.
data:image/s3,"s3://crabby-images/32961/329611a87efecf4b29e645c23b3370be8e59008a" alt=""
Going Further
Scaling with Anchors
Anchors allow you to control how a given View scales. You can set the anchor to any direction. By default, the anchor is center.
In the following example, when supplied with a .bottomTrailing
anchor, the Text scales down, while anchored to the bottom trailing edge.
There are nine different alignment options
topLeading
: The top left edge for left-to-right languages like English, top right edge for right-to-left languages like Arabictop
: The top center edgetopTrailing
: The top right edge for left-to-right languages like English, top left edge for right-to-left languages like Arabicleading
: The center left edge for left-to-right languages like English, center right edge for right-to-left languages like Arabiccenter
: The centertrailing
: The center right edge for left-to-right languages like English, center left edge for right-to-left languages like ArabicbottomLeading
: The bottom left edge for left-to-right languages like English, bottom right edge for right-to-left languages like Arabicbottom
: The bottom center edgebottomTrailing
: The bottom right edge for left-to-right languages like English, bottom left edge for right-to-left languages like Arabic
data:image/s3,"s3://crabby-images/00645/00645254ddf2b84fc509c22e3d69e472992a03a7" alt=""
Custom Anchors
You can define a custom anchor if none of the pre-defined alignment-based anchors work for your needs. For example, if you want a view to be anchored 40% on the x axis, and 10% on the y axis.
Do note that the axis starts from the top, 0, 0 is the top leading corner.
data:image/s3,"s3://crabby-images/1c4e6/1c4e6712c5e67087cbfccbd6b974990a0327fcf9" alt=""
Scaling with Animation
You can control the scale with a State variable.
In the following example, when the Button is tapped, the Text's scale will double.
data:image/s3,"s3://crabby-images/1a675/1a675690294ab3ff2e71132f517d9dd2770637ae" alt=""
To animate the transition, you can wrap the State change in a withAnimation block.
To find out more about the various options to customize the animation speed, curve, and more, check out the withAnimation article.
data:image/s3,"s3://crabby-images/a34d0/a34d05ed958b3c64ba18aa37d82ecdc83e8c42d1" alt=""
In These Collections
This article can also be found in these collections.