如何避免使用canvas生成带二维码海报踩坑
发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章主要介绍了如何避免使用canvas生成带二维码海报踩坑的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何避免使用canvas生成带二维码海报踩坑文章都会有所收获,
千家信息网最后更新 2025年11月13日如何避免使用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安全错误
数据库的锁怎样保障安全
中国网络安全最好的培训班
嘉定区品牌网络技术创新服务
aspace软件开发
数据库技术专科论文
网络安全法将近一年来
计算机网络技术英语数学
棋盟汇软件开发公司
怀旧服新开两组服务器
北邮网络安全教授
软件开发中的测试支持
领一年服务器
派出所数据库管理人员
甘肃浪潮服务器维修系统虚拟主机
西宁计算机网络技术
当前软件开发使用的软件
文章大数据库
网站跟数据库分开安全吗
医院信息平台数据库
数据库的小数点前的0没有
服务器配置性能不足怎么办
中国数据库应用技术大会
山烽互联网科技有限公司
二级网络安全员
小米手机原神怎么改服务器
软件开发 考试
怎么复制数据库记录到excel
国产数据库行业标准制订
英雄联盟各服务器的英文名称
sas9.4怎么连接数据库
西城区电子软件开发价目表