android 在线预览pdf文件(目前最全)

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

评论 38
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值