canvas.toDataURL后图片背景变成黑色

前情提要:压缩图片的时候,有张白底证件照toDataURL之后变成了黑底,非常疑惑。

查找一番之后发现貌似并没有特别好的解决方案,于是只能canvas绘制前填充白色背景

javascript 复制代码
canvas = document.getElementById("canvas"),
context = canvas.getContext("2d");
// 在canvas绘制前填充白色背景
context.fillStyle = "#fff";
context.fillRect(0, 0, canvas.width, canvas.height);

参考

https://blog.csdn.net/xiaolinlife/article/details/119350412

这边博文里解释了透明区域变成黑色背景 的原因:

canvas转换成jpeg之前移除alpha通道,所以透明区域被填充成了黑色。

这个aphpa通道,就是RGBA中的A,JEPE通常只有3个通道(红色、绿色和蓝色),而PNG可以有4个通道(红色、绿色、蓝色和透明度)(当然也可以只有3个通道)。

相关推荐
沄媪18 小时前
XSS 跨站脚本攻击
前端·ctf·xss
Bat U18 小时前
JavaEE|前端集合
前端
问心无愧051318 小时前
ctf show web入门260
android·前端·笔记
之歆18 小时前
Day22_CSS 函数完全指南:从变量到数学计算的现代样式编程
开发语言·前端·javascript·css·tensorflow·less
lichenyang45318 小时前
#鸿蒙基础复盘:生命周期、启动链路、路由跳转与真实需求定位
前端
ZengLiangYi18 小时前
Prompt 工程:让 LLM 输出结构化 JSON
前端·javascript·后端
Asmewill18 小时前
LangGraph学习笔记四(Node和Edge)
前端
何乐乐18 小时前
【Taro 5.0 技术与实践】 - 高性能 iOS 渲染层与 TaroUI 跨端框架介绍
android·前端·ios
猩球中的木子18 小时前
什么是DNS解析
前端·vue.js·面试