webgl canvas系列——快速加背景、抠图、加水印并下载图片

简介: webgl canvas系列——快速加背景、抠图、加水印并下载图片

⭐前言

大家好,我是yma16,本文分享webgl canvas系列——快速抠图、加水印。

⭐canvas绘制图片

方法 作用
drawImage(image, x, y) image 是 image 或者 canvas 对象,x 和 y 是其在目标 canvas 里的起始坐标。
drawImage(image, x, y, width, height) width 和 height,这两个参数用来控制 当向 canvas 画入时应该缩放的大小


js使用drawImage绘制图片

function drawImg() {
    const canvas = document.getElementById("tutorial");
    if (canvas.getContext) {
        const ctx = canvas.getContext("2d");
        const img = new Image();
        img.onload = function () {
            ctx.drawImage(img, 0, 0);
        };
        img.src = "/src/assets/csdn.png";
    }
    else {
        console.log('不支持canvas')
    }
}
window.onload = () => {
    drawImg()
}

💖给png图片加背景

js先填充cavans背景在画图

function drawImg() {
    const canvas = document.getElementById("tutorial");
    if (canvas.getContext) {
        const ctx = canvas.getContext("2d");
        // background
        ctx.fillStyle = 'rgba(0, 0, 200, 0.5)';
        ctx.globalAlpha = 1
        ctx.fillRect(0, 0, ctx.canvas.width, ctx.canvas.height)
        const img = new Image();
        img.onload = function () {
            ctx.drawImage(img, 35, 0);
        };
        img.src = "/src/assets/csdn.png";
    }
    else {
        console.log('不支持canvas')
    }
}
window.onload = () => {
    drawImg()
}

效果

💖cavans下载图片

方法 作用
canvas.toDataURL(type, encoderOptions); HTMLCanvasElement.toDataURL() 方法返回一个包含图片展示的 data URI。可以使用 type 参数指定其类型,默认为 PNG 格式。图片的分辨率为 96dpi
  • 如果画布的高度或宽度是 0,那么会返回字符串“data:,”。
  • 如果传入的类型非“image/png”,但是返回的值以“data:image/png”开头,那么该传入的类型是不支持的。 Chrome
  • 支持“image/webp”类型。

使用toDataURL属性下载

function downloadImage(dataURL, filename) {
    // 创建一个a元素,用于触发下载
    var link = document.createElement('a');
    link.download = filename;
    link.href = dataURL;
    link.click();
}
window.onload = () => {
    document.getElementById('down-btn').addEventListener('click', function () {
        const imgData = document.getElementById('tutorial').toDataURL("image/png");
        downloadImage(imgData, 'canvas图片')
    })
}

下载成功的效果效果

💖cavans上传图片并抠图

前期的准备

html原生上传图片 并使用canvas绘制图片

html结构

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link href="style.css" rel="stylesheet" type="text/css" />
    <title>canvas_调试</title>
</head>
<body>
    <div class="title">
        canvas
    </div>
    <div>
        <label for="avatar">选择图片上传:</label>
        <br>
        <input type="file" id="avatar" name="avatar" accept="image/png, image/jpeg" />
        <div id="preview-img">
        </div>
    </div>
    <div class="container">
        <canvas id="tutorial" width="250" height="100">
            current stock price: $3.15 +0.15
        </canvas>
    </div>
    <div>
        <button id="clear-back">
            自动抠图
        </button>
    </div>
    <br>
    <div>
        <button id="down-btn">
            下载图片
        </button>
    </div>
    <script src="script.js"></script>
</body>
</html>

js逻辑

const config = {
    cavansDom: null,
    uploadImgData: null,
}
function InitCanvas() {
    const canvas = document.getElementById("tutorial");
    config.cavansDom = canvas
    if (canvas.getContext) {
        const ctx = canvas.getContext("2d");
        // background
        ctx.fillStyle = 'rgba(0, 0, 200, 0.5)';
        ctx.globalAlpha = 1
        ctx.fillRect(0, 0, ctx.canvas.width, ctx.canvas.height)
        const img = new Image();
        img.onload = function () {
            ctx.drawImage(img, 35, 0);
        };
        img.src = "/src/assets/csdn.png";
    }
    else {
        console.log('不支持canvas')
    }
}
function drawImg(){
    canvas=config.cavansDom 
    if (canvas.getContext) {
        const ctx = canvas.getContext("2d");
        const img = new Image();
        img.onload = function () {
            const width=img.width
            const height=img.height
            canvas.width=width
            canvas.height=height
            ctx.drawImage(img, 0, 0);
        };
        img.src = config.uploadImgData
        console.log('img.src',img.src)
    }
    else {
        console.log('不支持canvas')
    }
}
function downloadImage(dataURL, filename) {
    // 创建一个a元素,用于触发下载
    var link = document.createElement('a');
    link.download = filename;
    link.href = dataURL;
    link.click();
}
function initUploadImg() {
    const input = document.getElementById('avatar')
    input.addEventListener('change', function (e) {
        console.log('e')
        const curFiles = input.files;
        console.log('curFiles', curFiles)
        config.uploadImgData = URL.createObjectURL(curFiles[0]);
        drawImg()
    })
}
function initDown() {
    document.getElementById('down-btn').addEventListener('click', function () {
        const imgData = config.cavansDom.toDataURL("image/png");
        downloadImage(imgData, 'canvas图片')
    })
}
// 抠图
function clearColor(){
    
}
window.onload = () => {
    InitCanvas()
    initDown()
    initUploadImg()
}

效果:实现了图片的上传并使用canvas适配绘制图片

上传csdn的个人头像

抠图逻辑:

为了实现抠图效果,可以使用绘图上下文的globalCompositeOperation属性来控制绘制的方式。其中,source-in和source-out是实现抠图的两种常用方式。

  • 使用source-in时,绘图上下文会根据Canvas上已有的内容和新绘制的图像的像素进行合并,只保留二者重叠的部分。通过调整绘图上下文的globalAlpha属性,可以实现抠图的透明效果。
  • 使用source-out时,绘图上下文会根据Canvas上已有的内容和新绘制的图像的像素进行合并,只保留二者不重叠的部分。同样,可以通过调整绘图上下文的globalAlpha属性,实现抠图的透明效果。

source-in效果

// 抠图
function clearColor(){
    document.getElementById('clear-back').addEventListener('click',function(){
        const ctx = config.cavansDom.getContext("2d");
        ctx.globalCompositeOperation = "source-in";
        ctx.fillStyle = "rgba(0, 0, 0, 0.5)"; // 设置抠图的透明度
        ctx.fillRect(0, 0, canvas.width, canvas.height);
    })
}

效果对比

source-out效果

// 抠图
function clearColor(){
    document.getElementById('clear-back').addEventListener('click',function(){
        const ctx = config.cavansDom.getContext("2d");
        ctx.globalCompositeOperation = "source-out";
        ctx.fillStyle = "rgba(0, 0, 0, 0.5)"; // 设置抠图的透明度
        ctx.fillRect(0, 0, canvas.width, canvas.height);
    })
}

效果对比

💖cavans添加文字水印

要在JavaScript的canvas上添加文字水印,可以使用以下代码:

const canvas = document.getElementById("myCanvas");
const ctx = canvas.getContext("2d");
ctx.font = "30px Arial";
ctx.fillStyle = "rgba(0, 0, 0, 0.5)";
ctx.fillText("Watermark", 10, 50);

首先,通过getElementById函数获取到canvas元素,并通过getContext函数获取到2D绘图上下文对象ctx。

然后,设置字体样式和颜色,可以使用font属性和fillStyle属性,分别设置字体大小和颜色。

最后,使用fillText方法绘制文字水印,传入要显示的文字、x坐标和y坐标。

添加水印成功

💖inscode 完整代码块

⭐结束

本文分享到这结束,如有错误或者不足之处欢迎指出!

目录
相关文章
|
11月前
threeJs用精灵模型Sprite实现下雨效果
这篇文章介绍了使用Three.js中的Sprite(精灵)模型来实现下雨特效的方法和技术细节。
429 2
threeJs用精灵模型Sprite实现下雨效果
|
存储 API
vue3中如何动态自定义创建组件并挂载
vue3中如何动态自定义创建组件并挂载
980 90
|
10月前
|
前端开发 JavaScript
怎么在vite项目中全局导入一个scss文件
在Vite项目中全局导入SCSS文件的方法:通过配置`vite.config.js`中的`css.preprocessorOptions.scss.additionalData`属性,可以将SCSS变量或混合内容全局引入。此方法同样适用于LESS文件。详情参见Vite官方文档。
640 1
怎么在vite项目中全局导入一个scss文件
|
机器学习/深度学习 前端开发 JavaScript
使用JavaScript精确裁剪图像的空白部分
【8月更文挑战第20天】
575 5
|
11月前
|
机器学习/深度学习 自然语言处理 前端开发
前端大模型入门:Transformer.js 和 Xenova-引领浏览器端的机器学习变革
除了调用API接口使用Transformer技术,你是否想过在浏览器中运行大模型?Xenova团队推出的Transformer.js,基于JavaScript,让开发者能在浏览器中本地加载和执行预训练模型,无需依赖服务器。该库利用WebAssembly和WebGPU技术,大幅提升性能,尤其适合隐私保护、离线应用和低延迟交互场景。无论是NLP任务还是实时文本生成,Transformer.js都提供了强大支持,成为构建浏览器AI应用的核心工具。
1982 1
|
JavaScript
Vue3使用全局函数或变量的两种常用方式
这篇文章介绍了Vue 3中实现全局函数或变量的两种方法:一种是使用`provide/inject`进行依赖注入,另一种是利用`app.config.globalProperties`和`getCurrentInstance()`来注册全局属性。
1857 2
Vue3使用全局函数或变量的两种常用方式
|
JavaScript
如何对ElementUI、ElementPlus中的Tree树组件进行美化,如增加辅助线、替换展开收起图标、点击节点后文字高亮等效果?本文给你答案!
本文介绍了如何对ElementUI和ElementPlus的Tree树组件进行美化,包括增加辅助线、替换展开收起图标、点击节点后文字高亮等效果,并提供了详细的代码示例和实现效果。
3099 0
如何对ElementUI、ElementPlus中的Tree树组件进行美化,如增加辅助线、替换展开收起图标、点击节点后文字高亮等效果?本文给你答案!
|
缓存 算法 前端开发
协同文档工作机制简介
随着在线办公的兴起,传统办公套件 Office 的在线化需求也随之增加。钉钉文档作为钉钉核心办公套件之一,上线已经三年,其间持续迭代,已成为一个极其复杂的产品。对前端工程师而言,协同文档是一个较为有挑战的领域,除了传统天坑富文本编辑器外,还引入了协同编辑这一挑战,钉钉文档甚至还支持专业排版能力。 来自钉钉的前端技术专家本杰,就在第十六届D2前端技术论坛进行了分享,本次分享以钉钉文档为例,简述协同文档的工作机制。
886 0
协同文档工作机制简介
|
存储 算法 大数据
程序员的职业素养:技术追求与人文关怀的结合
程序员的职业素养:技术追求与人文关怀的结合
246 2
程序员的职业素养:技术追求与人文关怀的结合
|
JavaScript
在Vue3+ElementPlus项目中使用具有懒加载的el-tree树形控件
在Vue 3和Element Plus项目中实现具有懒加载功能的el-tree树形控件,以优化大数据量时的页面性能。
2663 0