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

需求

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

7965652b572d

image.png

业务场景

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

7965652b572d

image.png

实现思路

1 需要把网页转化为canvas,借用了html2canvas

2 需要记住区域框的位置信息,利用drawImage方法实现区域截屏

3 生成截屏到oss

html2canvas使用方法

基本语法

html2canvas(element, options)

element: html的dom元素,options为参数配置项

7965652b572d

image.png

实现过程中遇到的问题

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

7965652b572d

image.png

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

7965652b572d

image.png

既然是写在两个项目中的代码,就牵扯到数据之间的相互传递了,先买个关子,后面代码中会提到

2 因为要实现再打开的时候,记住截屏的页面,问了officeweb365那边,展示不支持这个方法,于是想到了用pdf.js,恰巧officeweb365有个可以把所有文件都转化成pdf文件的功能

7965652b572d

image.png

自己的业务代码.previewDialog

html部分

7965652b572d

image.png

js部分

7965652b572d

image.png

officeweb365服务器上静态页面代码

html部分

scrolling="auto" sandbox="allow-same-origin allow-scripts allow-popups allow-forms">

js部分

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

pdf.js 打开文档拼接地址

7965652b572d

image.png

获取打开pdf在第几页

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

7965652b572d

image.png

pageNumber = history.files[0].page // 获取当前页码

获取当前页码的dom元素转化为canvas

7965652b572d

image.png

业务代码截屏功能实现

html

7965652b572d

image.png

接收刚刚传过来的参数

7965652b572d

image.png

实现效果

开始截屏

7965652b572d

image.png

7965652b572d

image.png

7965652b572d

image.png

7965652b572d

image.png

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值