NEW: Subscribe to Hacking with Swift+ and accelerate your learning! >>

How to support pinch to zoom in a UIScrollView

Swift version: 5.2

Paul Hudson    @twostraws   

Making a scroll view zoom when you pinch is a multi-step approach, and you need to do all the steps in order for things to work correctly.

First, make sure your scroll view has a maximum zoom scale larger than the default of 1.0. You can change this in Interface Builder if you want, or use the maximumZoomScale property in code.

Second, make your view controller the delegate of your scroll view. Again, you can do this in Interface Builder by Ctrl-dragging from the scroll view to your view controller.

Third, make your view controller conform to the UIScrollViewDelegate protocol, then add the viewForZooming(in:) method, like this:

func viewForZooming(in scrollView: UIScrollView) -> UIView? {
    return someView
}

That's it for code, but make sure you create your layouts consistently – whether you use Auto Layout or not, you need to be careful to follow Apple's instructions.

Subscribe to Hacking with Swift+

Sponsor Hacking with Swift and reach the world's largest Swift community!

Available from iOS 2.0

Similar solutions…

About the Swift Knowledge Base

This is part of the Swift Knowledge Base, a free, searchable collection of solutions for common iOS questions.

BUY OUR BOOKS
Buy Pro Swift Buy Swift Design Patterns Buy Testing Swift Buy Hacking with iOS Buy Swift Coding Challenges Buy Swift on Sundays Volume One Buy Server-Side Swift (Vapor Edition) Buy Advanced iOS Volume One Buy Advanced iOS Volume Two Buy Advanced iOS Volume Three Buy Hacking with watchOS Buy Hacking with tvOS Buy Hacking with macOS Buy Dive Into SpriteKit Buy Swift in Sixty Seconds Buy Objective-C for Swift Developers Buy Server-Side Swift (Kitura Edition) Buy Beyond Code

Was this page useful? Let us know!

Average rating: 3.7/5

Link copied to your pasteboard.