Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Enable zooming/pinch on UIWebView

Tags:

pdf

uiwebview

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

like image 720
David Avatar asked Aug 20 '11 20:08

David


5 Answers

Make sure you checked "Scales page to fit"

like image 164
JEzu Avatar answered Nov 18 '22 02:11

JEzu


you can use webView.scalesPageToFit=YES; programmatically

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

like image 46
Nithinbemitk Avatar answered Nov 18 '22 03:11

Nithinbemitk


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. :)

like image 29
iPatel Avatar answered Nov 18 '22 03:11

iPatel


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

like image 25
Scooter Avatar answered Nov 18 '22 02:11

Scooter


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

like image 18
Ashu Avatar answered Nov 18 '22 02:11

Ashu