Canvas自定义图片大小及蒙版与生成gif图

简介: Html的Canvas主要通过js脚本做一些图形化操作。Canvas是一个矩形区域,您可以控制其每一像素。canvas 拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。

Html的Canvas主要通过js脚本做一些图形化操作。Canvas是一个矩形区域,您可以控制其每一像素。canvas 拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。

如果有个需求,我们只想要用户相册图片中某个区域的内容,其余区域设为透明?

实现

  1. 先改变图片的大小
    使用一个开源的canvas库pica
// Resize from Canvas/Image to another Canvas
pica.resize(from, to, {
  unsharpAmount: 80,
  unsharpRadius: 0.6,
  unsharpThreshold: 2
})
.then(result => console.log('resize done!'));
img_82aa2f6339a31076c89bd8661e36dd08.png
测试效果
  1. 实现图片的蒙版
    图片蒙版主要是图片的叠加模式进行处理,参考以下链接
    图片组合类型
ctx.save();
ctx.drawImage(mask_img, 0, 0);
ctx.globalCompositeOperation = "source-in";
ctx.drawImage(our_img, 0, 0);
ctx.restore();
img_4bbe67ea83c792b1d20d4b1d7a76faa9.png
mask.png

img_7628d44a644a59d6e9d9d1f84ff6f636.png
our_img

img_f4f1eb1ce8bc55fe40e34e2f3462b5af.png
蒙版效果图
  1. 关于如何生成gif图,使用gif.js库。
                var gif = new GIF({
                    workers: 2,
                    quality: 10,
                    background: "#ffffff00",
                    transparent:"ff0000"
                });

                
                gif.addFrame(img1);
                gif.addFrame(img2);
                gif.on('finished', function(blob) {
                    // window.open(URL.createObjectURL(blob));
                    var url = URL.createObjectURL(blob);
                    document.getElementById("gif").setAttribute("src",url)

                });

                gif.render();

最后

这里主要介绍了一些前端对图片处理的操作。

相关文章
|
存储 JSON JavaScript
VUE2(七)VUE配置.env文件使用
公司的项目是基于vue2搭建的。 之前一直是采用一个.env文件来存储变量,然后在打包的时候修改.env文件中对应的变量的值。 但是这样做现阶段有两个小问题:
901 0
|
JavaScript 前端开发 网络安全
Video.js实现在html页面播放rtmp流媒体
Video.js实现在html页面播放rtmp流媒体
1763 0
|
JavaScript 前端开发 搜索推荐
ECharts词云图(案例一)+配置项详解
ECharts,百度的JavaScript图表库,支持词云图(自5.0版起),借助`echarts-wordcloud`插件。配置词云图涉及`tooltip`(如显示、颜色、边框等)和`series`(类型、形状、大小范围等)。示例代码展示了如何在HTML中引入依赖并配置词云图,包括数据、形状、大小、颜色等。完整代码和依赖可下载。调整这些配置可创建个性化词云图。参阅官方文档获取不同版本详情。
3972 4
 ECharts词云图(案例一)+配置项详解
|
Linux
linux中查看某个文件夹下文件的个数和大小
这篇文章介绍了在Linux系统中使用各种命令(如`stat`、`wc`、`du`和`ls`)来查看文件夹下文件的个数和大小的方法。
2294 5
linux中查看某个文件夹下文件的个数和大小
|
安全 Linux 网络安全
【工具使用】几款优秀的SSH连接客户端软件工具推荐FinalShell、Xshell、MobaXterm、OpenSSH、PUTTY、Terminus、mRemoteNG、Terminals等
【工具使用】几款优秀的SSH连接客户端软件工具推荐FinalShell、Xshell、MobaXterm、OpenSSH、PUTTY、Terminus、mRemoteNG、Terminals等
121941 0
|
JavaScript 前端开发 定位技术
maptalks使用高德的瓦片如何进行配置?
maptalks使用高德的瓦片如何进行配置?
824 12
.cer 文件添加到钥匙串报错:不能修改“System Roots”钥匙串
1、报错信息: 不能修改“System Roots”钥匙串: 要更改根证书是否会被信任,请在“钥匙串访问”中打开它,然后修改它的信任设置 2、网上搜索的答案都是: 钥匙串访问的界面左侧,选择“登录”或login按钮,直接将.
5942 0
|
搜索推荐 数据可视化 前端开发
ECharts 词云图案例【用户画像】:创意蒙版应用
使用ECharts创建词云图,结合蒙版技术提升可视化创意。通过设置`maskImage`属性,将自定义图像作为词云的外形,如用户画像。案例中详细介绍了HTML结构、ECharts配置及蒙版图像加载过程,鼓励探索SVG路径和CSS样式以实现更多个性化效果。代码和依赖可下载,激发更多数据可视化灵感。
922 0
 ECharts 词云图案例【用户画像】:创意蒙版应用
|
前端开发 JavaScript Java
springboot 集成easy-captcha实现图像验证码显示和登录
springboot 集成easy-captcha实现图像验证码显示和登录
833 0
|
人工智能 Serverless API
AI 绘画平台难开发,难变现?试试 Stable Diffusion API Serverless 版解决方案
AI 绘画平台难开发,难变现?试试 Stable Diffusion API Serverless 版解决方案