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

android 在线预览pdf文件(目前最全)相关推荐

  1. android 在线预览pdf文件

    android原生webView不支持预览pdf文件,ios却可以,所以android想要实现在线预览webView要通过其他方法,有以下几种方法: 1.andorid原生自带的pdf管理库,主要提供 ...

  2. 关于Android 在线预览PDF文件

    本篇文章大部分为转载内容,不过最后有我自己使用后的小总结,原文地址:https://www.jianshu.com/p/9e3ff8385e6f Android PdfViewer: 项目地址: ht ...

  3. Android在线预览pdf文件的几种方式

    Android原生WebView不支持预览pdf文件,ios却可以,所以Android想要实现在线预览WebView要通过其他方法,有以下几种方法: 第一种方式: andorid原生自带的pdf管理库 ...

  4. uniapp在线预览pdf文件

    公司要求uniapp打包的h5和app都要能在线预览pdf文件.最开始是想找uniapp的插件,去插件市场搜了下,没得几个插件可用,且需要收费,所以直接用的pdf.js插件实现,在h5以及h5打包的a ...

  5. html中在线预览pdf文件之pdf在线预览插件

    html中在线预览pdf文件之pdf在线预览插件 最近遇到一个需求,要在html页面查看pdf生成的pdf文件! 翻来覆去找到两种办法 ,最后采用了jquery.media.js插件 方式一 将pdf ...

  6. html做在线预览pdf文件,html中在线预览pdf文件之pdf在线预览插件

    html中在线预览pdf文件之pdf在线预览插件 最近遇到一个需求,要在html页面查看pdf生成的pdf文件! 翻来覆去找到两种办法 ,最后采用了jquery.media.js插件 方式一 将pdf ...

  7. 如何在html中在线预览pdf文件?

    方法1:使用 jquery js 库 1.引入 jquery-3.1.1.min.js 和 jquery.media.js 两个js文件,下载保存到本地 下载连接:jquery-3.1.1.min.j ...

  8. Vue-pdf实现在线预览PDF文件

    前言 在大多数项目中都会遇到在线预览PDF文件,项目使用的是element ui,使用vue-pdf实现. 安装依赖 npm install --save vue-pdf 相关参数 参数介绍: url ...

  9. 网页中实现安卓手机在线预览PDF文件

    写在前面:本文为转载,原文链接:https://blog.csdn.net/super_DuoLa/article/details/90207965原文链接 苹果手机可以直接在线预览PDF文件,而安卓 ...

最新文章

  1. Unity GUI(uGUI)使用心得与性能总结
  2. 老婆,我会好好爱你的
  3. android 后台邮件发送,Android邮件发送
  4. 关于递归函数,非递归函数中引用传参的问题
  5. Linux文本编辑器之vim
  6. Nhibernate与代码生成器介绍(转载)
  7. 执行mount挂载命令 报错:mount: you must specify the filesystem type
  8. 从后台servlet中,获取jsp页面输入的值,来删除用户一行信息
  9. System.Data.SQLite 支持所有(32位、64位的资源下载包)
  10. navicat激活失败
  11. 联想计算机怎么改为光驱启动,联想笔记本光驱启动设置方法
  12. 使用DeepAR实现股价预测
  13. java DNS域名解析
  14. Scratch快速入门(一)
  15. 正则验证车牌号码(包括新能源车牌)
  16. 《动手学深度学习》环境搭建全程详细教程 window用户
  17. qt -- QSpinBox、QDoubleSpinBox
  18. JAVA学习笔记(三十一)-电影系统案例
  19. 查违章老显示服务器维护中咋回事,违章查询怎么老显示系统正在维护呢,为什么违章查询总是显示维护状态?...
  20. 不小心点了计算机一键还原怎么操作,教你电脑一键还原怎么操作

热门文章

  1. java开发的游戏测试_用java编写。模拟一个简单的测试打字速度的游戏
  2. 【深度之眼Python基础+数据科学入门训练营】第八章 文件、异常和模块
  3. 使用证件照api接口快速上线证件照业务-超详细!
  4. spring的依赖注入 -------基于注解方式
  5. matlab设置xyz,matlab基本XYZ立体绘图命令
  6. Day374.shiro授权Shiro+jsp整合Springboot -Shiro
  7. 法线向量如何归一化(Normalize)
  8. 架构师如何设计架构,架构师的架构思路
  9. jQuery实现常见的轮播图效果
  10. Coursera登不上的全套方法