【踩坑】为base64编码的图片生成截图不显示
来源:互联网 发布:ps色环插件 for mac 编辑:程序博客网 时间:2024/05/16 08:34
问题
在effevo中设置个人头像时,会有无法显示的情况,还不稳定重现,终于抓到问题原因,下面分享下解决方法
解决方法
先看下原始写法
var imgBase64='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAFOSURBVFhH7ZOxTsMwEIZ9qVh5ChqLBalDI/EEvEUHJnbeg4fgWVgoEhtCtOI1GKr0jFNdIsf22ecuMPiTKv9Oznf/nRtVqVT+GqBVjG47tAt77mu3LcopDraFDUkRUiPZoHbZHQDUBW2LyRlpaI0ydJ0qDqju7Fg2tI2SmxzrjjuY66j0XPRhLEkswRgXedfYd0fSE7EcwRVwHbi0y3Xvxg3a/oavY8TVE7HcMwNccd85ACxIusxiuJH7NSYDXHEfrdcPJAO07u5JJnFrJb+CGIjwQzKg6c0rSTGTAW5kPvv99plkwOf32wfJJG4t0QSC60EMRo3GrEiekF5p0DV3EI16st0/0vbEGOtP7/rqdoXN8Z22M4I/NK0zUu5zV1V6lk0mGiH0N8bAJajFCz1h4Yyf3U0JqaklDYycayR3XQMiAy45M5KilUrlH6HUL3vJg2G2lVw/AAAAAElFTkSuQmCC'var img = window.document.createElement('img');img.src = imgBase64;//裁剪console.log('img.width , img.height', img.width, img.height); if (!img.width || !img.height) { console.log('img', img); throw { msg: '裁剪图片失败,请重新选择图片' }; } if (img.width > img.height) { var sx = (img.width - img.height) / 2; var sy = 0; var maxSize = img.height; } else { var sx = 0; var sy = (img.height - img.width) / 2; var maxSize = img.width; }var canvas = document.createElement('canvas'); canvas.width = size; canvas.height = size; var context = canvas.getContext("2d"); context.drawImage(img, sx, sy, maxSize, maxSize, 0, 0, size, size); var base64 = canvas.toDataURL('image/png'); var imgData = base64.split(',')[1]; var binaryData = window.atob(imgData); var ia = new Uint8Array(binaryData.length); for (var i = 0; i < binaryData.length; i++) { ia[i] = binaryData.charCodeAt(i); } var blob = new Blob([ia], { type: "image/png" }); console.log('blob.size', blob.size); return blob;
如上代码在99%的情况下都没有问题,但偶尔:
console.log('img.width , img.height', img.width, img.height);
这句话会输出:
img.width , img.height',0,0
注意,图片高度、宽度为0!!!!!!
图片是有高度和宽度的,但这种写法却没有,导致图片不显示!!!
如下写才是安全的:
img.onload=function(e){console.log('img.width , img.height', img.width, img.height); //开始截图等代码}
也就是说img.src=imgBase64后,不能保证img对象同步生成
effevo技术团队出品 (https://effevo.com)
0 0
- 【踩坑】为base64编码的图片生成截图不显示
- 网页显示base64编码的图片
- 图片 BASE64编码 JSP 显示
- 图片 BASE64编码 JSP 显示
- 图片转换为Base64编码
- 图片的Base64编码
- Base64编码的图片流直接嵌入到页面显示
- js 显示 base64编码 的二进制流 图片
- js 显示base64编码的二进制流网页图片
- 图片的base64编码实现以及网页上显示
- MFC加密Base64编码的图片,并显示
- BASE64编码的图片在网页中的显示问题
- 图片转 base64 编码显示(PHP)
- 图片转 base64 编码显示(PHP)
- HTML5上传图片base64编码显示缩略图
- 图片文件转换为base64编码
- js 将图片转换为base64编码
- 转化本地图片为base64编码
- 关于 javascript原型和继承的讲解
- 位运算
- 【Android开发杂技】输入法高度获取(可监听变化)
- hdu 4825(trie)
- 【Android】图片异步加载三方框架Universal Image Loader详细配置
- 【踩坑】为base64编码的图片生成截图不显示
- python导入自定义模块
- 单元格与九宫格的多选和单选问题
- sonar使用Oracle数据库时报org.elasticsearch.transport.BindTransportException: Failed to bind to [9001]的错误
- XMPP框架 微信项目开发之Socket聊天室的建立与登录
- UML学习笔记之用例图
- Androidstudio error(1,0)错误,和(2.0)错误
- 视图Ext.Viewport和窗口Ext.Window用法
- 将UIview的image保存到本地的方法