views:

1486

answers:

7

I am having some difficulty using a UIWebView to render PDF files on the iPad. Everything works fine in portrait mode, but turning the device to landscape produces strange visual quirkiness. Zooming in (but not out) even the slightest will correct it, but obviously that's not an ideal workaround.

The issue occurs with any PDF file (I have tried several, all stored locally in the bundle, not retrieved from the web). I also created a clone of the project for iPhone, which seems to work just fine, so the problem is iPad-specific. The problem occurs both in the simulator as well as on a physical iPad.

Screenshot

http://dev.boxkite.net/images/ipad/ipad-pdf.png

Code

 NSString* filePath = [[NSBundle mainBundle] pathForResource:@"test" ofType:@"pdf"];
 NSData* data = [NSData dataWithContentsOfFile:filePath];

 [self.webView 
  loadData:data
  MIMEType:@"application/pdf"
  textEncodingName:@"UTF-8"
  baseURL:nil];

Thanks so much for your time.

A: 

I believe this is one of the many simulator bugs.

jamone
Actually, it happens on the physical iPad as well.
Ash White
Oh, not good. I have it too but had been ignoring it as a sim bug. Wish my 3G iPad was here to test with...
jamone
Glad I'm not alone. Strange thing is that using Safari or MobileMail to view a PDF works fine, even though both of those use WebKit in the same way as I am.
Ash White
A: 

This is happening to me as well, really really infuriating. Anyone know if this problem is known to Apple? Seems like a problem with their code rather than anything we are doing wrong. The only way I found to fix it is to tell the UIWebView to reload the pdf after the orientation change - definitely not ideal (especially with large pdfs) - and even then the visual chop remains for a fraction of a second before the correct version appears.

Jon
A: 

The only way I can fix the rendering is to call reload on the UIWebView, but it's not pretty.

greenisus
A: 

Have you found a fix?

There should be some solution to it... and it is not a simulator bug. Also happens on my iPad :S

ThomasMB
Nothing yet. I suppose it's just a bug in the iPhone OS?
Ash White
+1  A: 

The only way to fix this problem is to when ever you rotate/change the size of your UIWebView is to call loadData: again. This leaves it on for around a second (depending on file size) but is not a terrible fix for now. It is certainly much better than calling loadRequest: again!

The bug has been submitted to apple and has been approved. No word on a fix date.

Jesse Naugher
+1  A: 

This is indeed a known bug, according to Apple.

A better work-around is to call

-[UIView setNeedsDisplay]

on every subview in the web view instance, like so:

for(UIView* subview in webView)
{
    for(UIView *reloadView in [subview subviews])
    {
        if([reloadView class] != [UIImageView class])
        {
            [reloadView setNeedsDisplay];
        }
    }
}
+1  A: 

It's a confirmed bug. I found a workaround that works for me. You can use this code when you resize your view or in the autorotate event.


for (UIView *v in [webView subviews]) {
  for (UIView *v2 in [v subviews]) {
    if ([v2 class] != [UIImageView class]) [v2 setNeedsDisplay];
  }
}

That's it.

Simone Maynard
Any chance this will be considered as using private APIs by Apple, and cause an app to be rejected?? (These sub-subviews are private)
Danra