NEW! Master Swift design patterns with my latest book! >>

How to support pinch to zoom in a UIScrollView

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.

Available from iOS 2.0

Did this solution work for you? Please pass it on!

Other people are reading…

About the Swift Knowledge Base

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

Download for free!

Want a free 75-minute video teaching functional programming, protocol-oriented programming, and more? This is your lucky day!

MASTER SWIFT NOW
Buy Practical iOS 12 Buy Pro Swift Buy Swift Design Patterns Buy Practical iOS 11 Buy Swift Coding Challenges Buy Server-Side Swift (Vapor Edition) Buy Server-Side Swift (Kitura Edition) Buy Hacking with macOS Buy Advanced iOS Volume One Buy Hacking with watchOS Buy Hacking with tvOS Buy Hacking with Swift Buy Dive Into SpriteKit Buy Swift in Sixty Seconds Buy Objective-C for Swift Developers Buy Beyond Code

Was this page useful? Let me know!

Average rating: 5.0/5

Click here to visit the Hacking with Swift store >>