android原生webView不支持预览pdf文件,ios却可以,所以android想要实现在线预览webView要通过其他方法,有以下几种方法:
一.andorid原生自带的pdf管理库,主要提供两个类pdfRender和pdfDocument,有兴趣的可以自己去了解一下,缺点就是必须是API>=21(也就是5.0以上)的版本才能支持,局限性太大。
二.一个github上面的开源库PdfViewer,项目地址: https://github.com/barteksc/AndroidPdfViewer ,功能很强大,使用也很广泛,但有一个很重要的硬伤,那就是会使apk增加16M左右的大小,很难让人接受。
三.也是一个github上的开源库PdfViewPager,项目路径是:https://github.com/voghDev/PdfViewPager ,可加载assets/SD卡/URL,使用比较方便,也不大,但不知道是否已经停止维护或是出现了bug,我在使用的时候报错,一直没解决,所以被我抛弃(可能自己技术不够罒ω罒)
四.mupdf,是一款轻量级的pdf浏览框架,基本上支持前面两者的功能,如果是文本的pdf文档还支持搜索,标注等功能。当之无愧的强大。虽说轻量,但编译出来的so库也不小。具体怎样我也没用过,所以唔知。
五.在webView中调用GoogleDocs实现在线预览,有个致命的缺点就是需要翻墙,所以果断放弃。
六.调起第三发支持PDF阅读的应用,比如手机上的某些阅读器等,缺点明显,需要用户手机安装能预览PDF的应用才行,局限性太大,要预览还得再装一个app,不合理也麻烦,用户体验很差。
七.通过PDF.js实现在线预览,这是一个github上的开源库。项目路径:https://github.com/mozilla/pdf.js
这里重点讲第七种,因为局限性很小(除非github上的PDF.js没了),实现的方式也有两种,一种是直接下载整个开源库,拷贝到自己的项目的assets文件下,这样的优点就是可以改该库里的代码(根据自己的需要),缺点就是这个库也不小,会占用一定的内存空间,所以我也不考虑,我们采用以下第二种方式。
首先,在assets下新建两个文件,pdf.html跟pdf.js,名字可以自己取,用的时候对应上就行
pdf.html文件如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width,initial-scale=1.0,maximum-scale=2.0,user-scalable=yes"/>
<title>PDF查看</title>
<style type="text/css">
canvas {
width: 100%;
height: 100%;
border: 1px solid black;
}
</style>
<script src="https://unpkg.com/pdfjs-dist@2.3.200/build/pdf.min.js"></script>
<script type="text/javascript" src="pdf.js"></script>
</head>
<body>
</body>
</html>
pdf.js代码如下:
var url = location.search.substring(1);
pdfjsLib.cMapUrl = 'https://unpkg.com/pdfjs-dist@2.3.200/cmaps/';
pdfjsLib.cMapPacked = true;
var pdfDoc = null;
function createPage() {
var div = document.createElement("canvas");
document.body.appendChild(div);
return div;
}
function renderPage(num) {
pdfDoc.getPage(num).then(function (page) {
var viewport = page.getViewport({scale:2.0});
var canvas = createPage();
var ctx = canvas.getContext('2d');
canvas.height = viewport.height;
canvas.width = viewport.width;
page.render({
canvasContext: ctx,
viewport: viewport
});
});
}
pdfjsLib.getDocument(url).promise.then(function (pdf) {
pdfDoc = pdf;
for (var i = 1; i <= pdfDoc.numPages; i++) {
renderPage(i)
}
});
pdf.js文件中的 var viewport = page.getViewport(2.0); 是为了解决某些机型预览的时候显示模糊的问题;
PDFJS.cMapUrl = 'https://unpkg.com/pdfjs-dist@1.9.426/cmaps/'; PDFJS.cMapPacked = true;是为了解决PDF内容显示不完整的问题。
pdf.html文件中就将PDF.js链入了html中:<script src="https://unpkg.com/pdfjs-dist@1.9.426/build/pdf.min.js"></script>
使用方式直接用webView.loadUrl("file:///android_asset/pdf.html?"+URL文件) URL文件可以是本地文件,也可以线上的pdf文件路径。这样就可以实现在线预览了,很简单,下面是可能会遇到的一些问题。
出现的问题:
1、WebView加载时控制台报错:Faild load file:你要展示的文件路径,这是因为WebView默认不允许加载本地文件,添加代码:WebView.getSettings().setAllowUniversalAccessFromFileURLs(true);即可。
2、缩放问题,我运行上去发现图片中文字太小,需要放大才能看,但是界面却不能缩放,
解决办法:
(1)WebView设置:mWebView.getSettings().setSupportZoom(true);
mWebView.getSettings().setBuiltInZoomControls(true);
mWebView.getSettings().setDisplayZoomControls(true);
mWebView.getSettings().setAllowUniversalAccessFromFileURLs(true); //设置可以访问URL
(2)show_pdf.html 文件修改:<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=4.0,user-scalable=yes"/>
width=device-width :表示宽度是设备屏幕的宽度
initial-scale=1.0:表示初始的缩放比例
minimum-scale=0.5:表示最小的缩放比例
maximum-scale=4.0:表示最大的缩放比例
user-scalable=yes:表示用户是否可以调整缩放比例
以上就是本博文的全部内容,有写得不好的地方,有什么需要建议的地方请留言,若觉得好请点个赞谢谢。
关注公众号:小陆小陆认真点 回复“pdf”即可立即获得demo源码,或者评论区留下邮箱,我看到了会发给你^_^
参考博文:https://blog.csdn.net/sunnyjerry/article/details/84581819 https://blog.csdn.net/guoxiaolongonly/article/details/76992138