html2canvas手机黑屏,html2canvas 生成海报图 开发中遇到的问题

本文主要探讨了在ios设备上使用html2canvas生成海报图时遇到的黑屏、白屏及图片不显示问题。解决方案包括设置canvas的y坐标、处理滚动条、确保图片加载完成后再绘制、添加crossOrigin属性。还分享了针对不同手机型号的图片加载问题的处理方法,并提供了一个在线demo供测试。
摘要由CSDN通过智能技术生成

ios里,生成的图片不显示

canvas.toDataURL('image/jpeg', 1.0)

使用image/jpeg格式,在指定图片格式为 image/jpeg 或 image/webp的情况下,可以从 0 到 1 的区间内选择图片的质量。

canvas 是弹出层时,底层有滚动条,会有部分空白

测试的时候,好奇为啥每次,生成的图片都缺一部分,而且都是从顶部开始空白,再绘制图片。

解决方案: 添加绘制坐标y起始位置 y: window.pageYOffset,

html2canvas(target, {

useCORS: true,

y: window.pageYOffset,

}).then(...)

canvas 白屏终极解决方案

不考虑图片加载问题,大多是因为没找到绘制的位置的原因,会导致白屏黑屏的现象。

而且也会有改动 海报图布局的情况,经常会调位置,再遇见缩小海报图展示的需求,就要改动很多了,所以现在一般都是,把canvas定位到屏幕外面,然后绘制生成图片。对图片放大缩小就容易的多。

解决方案:

html2canvas(target, {

useCORS: true,

y: (window.pageYOffset + window.innerHeight),

}).then(...)

ios 生成图片时显示时不显的,大图几乎不显示。

猜测是图片渲染的原因,为了确保能够生成图片,生成图片写在了所有图片加载

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值