一、浏览方式
1.使用iOS系统基础控件展示,通过UIWebView/WKWebView加载:
- 使用webView可加载本地PDF文件和网络PDF文件;
- 优点:开发难度简单;
- 缺点:功能较少,只可简单浏览;
NSURL *pdfURL = [NSURL fileURLWithPath:urlString];
NSURLRequest *request = [NSURLRequest requestWithURL:pdfURL];
//设置缩放
[self.webView setScalesPageToFit:YES];
[self.webView loadRequest:request];
2.自定义UIView,通过CoreGraphics框架底层接口绘制PDF:
- 使用CoreGraphics框架可以对PDF文件渲染到自定义view上;
- 优点:可以通过苹果提供的底层API接口对PDF文件数据流进行操作,可以做更精细的控制;
- 缺点:若需要做更细致的功能,开发难度较大;
CFURLRef pdfURL = CFBundleCopyResourceURL(CFBundleGetMainBundle(),
(__bridge CFStringRef)self.fileName, NULL, NULL);
CGPDFDocumentRef pdfDocument =
CGPDFDocumentCreateWithURL((CFURLRef)pdfURL);
CFRelease(pdfURL);
CGContextTranslateCTM(context, 0.0, self.bounds.size.height);
CGContextScaleCTM(context, 1.0, -1.0);
CGPDFPageRef page = CGPDFDocumentGetPage(pdfDocument, self.pageNumber);
CGContextSaveGState(context);
CGAffineTransform pdfTransform = CGPDFPageGetDrawingTransform(page,
kCGPDFCropBox, self.bounds, 0, true);
CGContextConcatCTM(context, pdfTransform);
CGContextDrawPDFPage(context, page);
CGContextRestoreGState(context);
3.使用iOS系统基础控件展示,通过QuickLook框架中的QLPreviewController进行展示:
- QLPreviewController需要用到QuickLook.framework,要在工程文件,Build Phases -> Link Binary With Libraries 中添加;
- 优点:开发难度简单;
- 缺点:功能较少,只可简单浏览;
QLPreviewController *vc = [[QLPreviewController alloc] init];
//设置数据源代理
vc.dataSource = self;
vc.title = [self.titleArray objectAtIndex:indexPath.row];
[self.navigationController pushViewController:vc animated:YES];
//实现QLPreviewControllerDataSource代理协议
#pragma mark - QLPreviewControllerDataSource
- (NSInteger)numberOfPreviewItemsInPreviewController:(QLPreviewController *)controller {
return 1;
}
- (id <QLPreviewItem>)previewController:(QLPreviewController *)controller previewItemAtIndex:(NSInteger)index {
NSString *fileName = [self.fileArray objectAtIndex:self.indexPath.row];
NSURL *url = [[NSBundle mainBundle] URLForResource:fileName withExtension:nil];
return url;
}
4.对PDF数据流进行处理,提取PDF数据流中的元素将其转化为HTML标签,从而将PDF转为HTML格式,通过webView加载进行展示,需要用到第三方开源库pdf.js:
- 优点:PDF文件转化为HTML格式之后,可以在webView代理方法中做更多功能处理;
- 缺点:不同浏览器可能存在兼容性问题;
- 兼容性:对于受限的一些特性,会有相对应的措施,具体详见;
- iOS集成pdf.js使用步骤见我的另一篇文章:iOS使用pdf.js打开PDF文件;
二、集成第三方SDK
三、GitHub开源资源
-
ILPDFKit:采用CoreGraphics框架,通过处理PDF数据流,识别PDF表单form格式,高亮并可以编辑;
-
PDFKitten: 采用CoreGraphics框架,通过处理PDF数据流,可进行文本搜索并高亮,但并不适用于所有PDF;
-
vfr/Reade: 采用CoreGraphics框架绘制功能,只能提供PDF阅读;
-
pdf2htmlEX: 提供服务器端pdf转html功能;
-
pdf.js:火狐浏览器PDF开源框架,采用webView,浏览pdf时转为html,可同时在iOS和安卓客户端进行处理;
四、总结
- 开源框架中,若只是对PDF文件进行浏览,满足需求有较多选择;
- 若需要对PDF文件进行标注、划线、涂鸦等高级操作,个人开发难度较大,建议使用第三方付费SDK;