如何避免使用canvas生成带二维码海报踩坑
发表于:2024-09-25 作者:千家信息网编辑
千家信息网最后更新 2024年09月25日,这篇文章主要介绍了如何避免使用canvas生成带二维码海报踩坑的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何避免使用canvas生成带二维码海报踩坑文章都会有所收获,
千家信息网最后更新 2024年09月25日如何避免使用canvas生成带二维码海报踩坑
这篇文章主要介绍了如何避免使用canvas生成带二维码海报踩坑的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何避免使用canvas生成带二维码海报踩坑文章都会有所收获,下面我们一起来看看吧。
问题如下
图片不显示
绘制渲染的时候图像不显示:是因为图片异步加载,所以canvas的操作需要放在onload事件中,否则图片会不显示,因为图片不止一张,建议放在promise中,用async,await调用
canvas最终生成图片分享出去,生成的图片不显示:是因为图像跨域问题,设置img的attr,'crossOrigin'为'Anonymous'就好了,但是要注意,如果不小心为base64也设置了这个参数,在低版本的安卓(我出现问题是在华为安卓4.4.2中)base64就不会显示。
图像模糊
一开始对安卓机型统一做了dpr=1的处理,结果安卓机上图片非常的模糊,圆角头像锯齿严重,网上的解决方法无一成功,后来还是将dpr设为window.devicePixelRatio就好了,只是图片的宽高最好设置为固定值,根据flexble自适应
部分代码示例
// 头像;const imgAvadar = await promiseLoadImg(this.userInfoExternal.headUrl);const imgSize = 40 * this.dpr;const imgPos = 24 * this.dpr;ctx.arc((this.canvas.width / 2), (imgPos + (imgSize / 2)), (imgSize / 2), 0, 2 * Math.PI);ctx.clip();ctx.drawImage(imgAvadar, ((this.canvas.width / 2) - (imgSize / 2)), imgPos, imgSize, imgSize);
new Promise(resolve => {
const img = new Image(); // base64添加了以下跨域配置,在低版本安卓中会不显示图片 if (src.indexOf('base64,') === -1) { img.setAttribute('crossOrigin', 'Anonymous'); } img.onload = function () { resolve(img); }; img.src = src;});
关于"如何避免使用canvas生成带二维码海报踩坑"这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对"如何避免使用canvas生成带二维码海报踩坑"知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。
图片
生成
安卓
海报
二维
二维码
图像
知识
问题
内容
头像
版本
篇文章
成功
事件
代码
价值
参数
只是
圆角
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
设计软件开发方向
vfp数据库保存命令
服务器断电无法启动数据库
政府采购 软件开发 源码
数据库四级含金量
深圳安卓应用软件开发公司
安卓软件开发培训费用
生物信息数据库有哪些类型
网络安全信任等级
数据库概念模型er图怎么画
哪种是主干网络技术
6字网络安全标语
数据库视图可以保存数据吗
山西煤矿网络安全等级测评招标
贵阳社区团购软件开发
网络安全检查迎检欢迎辞
美国网络安全的基础
凤凰金彩网络技术有限公司
网络安全宣传周用什么看
31岁学软件开发转行适合吗
我国网络安全产业的规模增长迅速
华为东莞软件开发
linux 数据库 脚本
数据库速成猴博士
lwip服务器发送数据失败
数据库系统概论填空题
fifa17 ea服务器
中国电信网络安全工作愿景
四川众信互联网科技
机关 网络安全法