107

I have an UIWebView with a pdf-file. It works fine. But how can i enable zooming on the pdf-file?

David
  • 1,071
  • 2
  • 7
  • 4

6 Answers6

233

Make sure you checked "Scales page to fit"

JEzu
  • 2,949
  • 1
  • 16
  • 6
46

you can use webView.scalesPageToFit=YES; programmatically

If you are using in xib than just click the check box "Scaling" scales Page to fit

Nithinbemitk
  • 2,710
  • 4
  • 24
  • 27
29

This Logic for zooming of UIWebView, no need to add UIWebView on UIScrollView

Well only problem with webView.scalesPageToFit = YES; is that, it will change initial content of font size but I found other option

Add <UIWebViewDelegate, UIScrollViewDelegate> to your .h file

Creation of your UIWebView.

self.mWebview = [[UIWebView alloc] init];
self.mWebview.delegate = self; /// set delegate method of UIWebView
self.mWebview.frame = CGRectMake(0, 35, self.view.bounds.size.width, self.view.bounds.size.height - 80); // set frame whatever you want..
[self.mWebview setOpaque:NO];
self.mWebview.backgroundColor = [UIColor clearColor];
[self.view addSubview:self.mWebview];

With load HTML file/content.

NSString* htmlString = [NSString stringWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"File Name"ofType:@"html"] encoding:NSUTF8StringEncoding error:nil];
[self.mWebview loadHTMLString:htmlString baseURL:[NSURL fileURLWithPath:[[NSBundle mainBundle] bundlePath]]];


#pragma mark -
#pragma mark - Webview Delegate Methods

- (void) webViewDidFinishLoad:(UIWebView *)webView
{
    webView.scrollView.delegate = self; // set delegate method of UISrollView
    webView.scrollView.maximumZoomScale = 20; // set as you want.
    webView.scrollView.minimumZoomScale = 1; // set as you want.

    //// Below two line is for iOS 6, If your app only supported iOS 7 then no need to write this.
    webView.scrollView.zoomScale = 2;
    webView.scrollView.zoomScale = 1;
}

#pragma mark -
#pragma mark - UIScrollView Delegate Methods

- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(float)scale
{
    self.mWebview.scrollView.maximumZoomScale = 20; // set similar to previous.
}

NOTE: I had to tested on Mac OS X - 10.9.3 with Xcode 5.1.1 and iOS version 6.1 and latter.

I hope this will helpful for you. :)

iPatel
  • 46,010
  • 16
  • 115
  • 137
  • 1
    The scrollViewDidEndZooming wasn't needed for me to get zooming working correctly. Not sure what the intent of that code is as it just is resetting the same value that was set earlier to the exact same value! – Norman H Apr 06 '15 at 20:46
  • 1
    Ya exactly, why is the scrollViewDidEndZooming part needed at all? But other than that, superb answer. It made even those pages zoom which were not getting zoomed by just setting the "Scales page to fit" property. – GKK Nov 02 '16 at 09:41
25

I know this question is pretty old, but for everyone that is using a storyboard and prefers a visual answer here it is. Just check this box in the WebView's Attributes Inspector:

enter image description here

Scooter
  • 4,068
  • 4
  • 32
  • 47
18

If you want do by programmatically then use

webView.scalesPageToFit = true; 

If you are using storyboard then you have to tick check box "Scaling" scales Page to fit enter image description here

Community
  • 1
  • 1
Ashu
  • 3,373
  • 38
  • 34
7

You MUST set scalesPageToFit=YES for any pinching and zooming to work on a UIWebView. It work for me.

Sargis
  • 1,196
  • 1
  • 18
  • 31