美文网首页那些年遇到的坑
vue实现网页区域截屏(结合html2canvas,pdf.js

vue实现网页区域截屏(结合html2canvas,pdf.js

作者: 筱贰_梁 | 来源:发表于2020-10-22 17:12 被阅读0次

需求

打开office文件后,可以实现区域截屏,并且记住当前截屏位置的文档页码


image.png

业务场景

这边office文件用的officeweb365打开的,打开方式是officeweb365那边的方法


image.png

实现思路

1 需要把网页转化为canvas,借用了html2canvas
2 需要记住区域框的位置信息,利用drawImage方法实现区域截屏
3 生成截屏到oss

html2canvas使用方法

基本语法
html2canvas(element, options)
element: html的dom元素,options为参数配置项


image.png

实现过程中遇到的问题

1 因为文件是用officeweb365打开的,在获取iframe dom元素的时候,会报一个跨域的问题


image.png

因为有个服务器专门部署了预览officeweb365的配置服务,于是想我在这个服务器下写个静态页面,然后跟我这边的业务代码进行交互(跨域问题成功解决了)

image.png

既然是写在两个项目中的代码,就牵扯到数据之间的相互传递了,先买个关子,后面代码中会提到
2 因为要实现再打开的时候,记住截屏的页面,问了officeweb365那边,展示不支持这个方法,于是想到了用pdf.js,恰巧officeweb365有个可以把所有文件都转化成pdf文件的功能


image.png
自己的业务代码.previewDialog
html部分
image.png
js部分
image.png
officeweb365服务器上静态页面代码
html部分
<div class='preview-content'>
    <iframe id="iframe01" class='iframeBox' :src='openUrl' style="border: 0;" height="100%" width="100%"
        scrolling="auto" sandbox="allow-same-origin allow-scripts allow-popups allow-forms">
    </iframe>
</div>
js部分

技术难点: 因为要记住页码,所有实现截屏也是在某一页的基础上进行截屏,所有首先要定位当前打开pdf文件在第几页

pdf.js 打开文档拼接地址
image.png
获取打开pdf在第几页

发现利用pdf.js打开文件的时候,会在localStorage里面存储页面信息


image.png
    pageNumber = history.files[0].page // 获取当前页码
获取当前页码的dom元素转化为canvas
image.png

业务代码截屏功能实现

html
image.png
接收刚刚传过来的参数
image.png

实现效果

开始截屏

image.png
image.png
image.png
image.png

至此所有功能实现,感想就是坐下来认真去想一个需求怎么实现,最后还能圆满实现的感觉真的很棒!

不问他年同尘忘烟波,多少故事转身千秋,共勉!!!

相关文章

  • vue实现网页区域截屏(结合html2canvas,pdf.js

    需求 打开office文件后,可以实现区域截屏,并且记住当前截屏位置的文档页码 业务场景 这边office文件用的...

  • js截屏

    使用Html2canvas截屏 下载Html2canvas Html2canvas加载后将会浏览页面上的所有元素,...

  • phantomjs实现网页截屏

    最近做项目,需要实现网页抓屏。摸索后,决定采用phantomjs 实现。phantomjs 的功能很强大,做爬虫应...

  • 谷歌浏览器Chrome的截屏插件 - xCut

    xCut是一款谷歌浏览器的截屏插件,可快速选择网页区域截屏,并做简单画笔圈图编辑,简单轻量而又功能齐全。可以参考x...

  • Android之WebView网页滚动截图

    WebView 网页滚动截屏,可对整个网页进行截屏而不是仅当前屏幕哦!注意若Web页面存在position:fix...

  • Android 截屏方式整理

    Android 实现截屏方式整理 可能的需求: 截自己的屏 截所有的屏 带导航栏截屏 不带导航栏截屏 截屏并编辑选...

  • html2canvas的使用

    html2canvas是什么 html2canvas 可以在浏览器端直接对整个或部分页面进行截屏。脚本通过读取DO...

  • 安卓截图笔记

    Android截屏 Android截屏的原理:获取具体需要截屏的区域的Bitmap,然后绘制在画布上,保存为图片后...

  • Android截屏方案

    Android截屏 Android截屏的原理:获取具体需要截屏的区域的Bitmap,然后绘制在画布上,保存为图片后...

  • Android实现指定控件区域截屏

网友评论

    本文标题:vue实现网页区域截屏(结合html2canvas,pdf.js

    本文链接:https://www.haomeiwen.com/subject/ibfpmktx.html