返回顶部
首页 > 资讯 > 精选 >js如何给图片打马赛克
  • 756
分享到

js如何给图片打马赛克

2023-06-15 02:06:02 756人浏览 独家记忆
摘要

这篇文章给大家分享的是有关js如何给图片打马赛克的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。效果演示canvas简介这个 html 元素是为了客户端矢量图形而设计的。它自己没有行为,但却把一个绘图 api 展现

这篇文章给大家分享的是有关js如何给图片打马赛克的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

效果演示

js如何给图片打马赛克

canvas简介

这个 html 元素是为了客户端矢量图形而设计的。它自己没有行为,但却把一个绘图 api 展现给客户端 javascript 以使脚本能够把想绘制的东西都绘制到一块画布上。

HTML5 标签用于绘制图像(通过脚本,通常是 JavaScript)

不过, 元素本身并没有绘制能力(它仅仅是图形的容器) - 您必须使用脚本来完成实际的绘图任务

getContext() 方法可返回一个对象,该对象提供了用于在画布上绘图的方法和属性

本手册提供完整的 getContext(“2d”) 对象属性和方法,可用于在画布上绘制文本、线条、矩形、圆形等等

标记和 SVG 以及 VML 之间的差异:

标记和 SVG 以及 VML 之间的一个重要的不同是, 有一个基于 JavaScript 的绘图 API,而 SVG 和 VML 使用一个 XML 文档来描述绘图。

这两种方式在功能上是等同的,任何一种都可以用另一种来模拟。从表面上看,它们很不相同,可是,每一种都有强项和弱点。例如,SVG 绘图很容易编辑,只要从其描述中移除元素就行。

要从同一图形的一个 标记中移除元素,往往需要擦掉绘图重新绘制它。

知识点简介

利用js创建图片

let img = new Image()//可以给图片一个链接img.src = 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=826495019,1749283937&fm=26&gp=0.jpg'//或者本地已有图片的路径//img.src = './download.jpg'//添加到HTML中document.body.appendChild(img)

canvas.getContext(“2d”)

语法:
参数 contextID 指定了您想要在画布上绘制的类型。当前唯一的合法值是 “2d”,它指定了二维绘图,并且导致这个方法返回一个环境对象,该对象导出一个二维绘图 API

let ctx = Canvas.getContext(contextID)

ctx.drawImage()

JavaScript 语法 1:
在画布上定位图像:

context.drawImage(img,x,y);

JavaScript 语法 2:
在画布上定位图像,并规定图像的宽度和高度:

context.drawImage(img,x,y,width,height);

JavaScript 语法 3:
剪切图像,并在画布上定位被剪切的部分:

JavaScript 语法
getImageData() 方法返回 ImageData 对象,该对象拷贝了画布指定矩形的像素数据。
对于 ImageData 对象中的每个像素,都存在着四方面的信息,即 RGBA 值:
R - 红色 (0-255)
G - 绿色 (0-255)
B - 蓝色 (0-255)
A - alpha 通道 (0-255; 0 是透明的,255 是完全可见的)
color/alpha 以数组形式存在,并存储于 ImageData 对象的 data 属性中

var imgData=context.getImageData(x,y,width,height);

ctx.putImageData()

putImageData() 方法将图像数据(从指定的 ImageData 对象)放回画布上。

接下来跟着我一步一步做完这个小功能叭~

step-by-step

准备好我们的图片,并添加上我们的方法

<body>    <img src="./download.jpg">    <button onclick="addCanvas()">生成Canvas</button>    <button onclick="generateImg()">生成图片</button></body>

js如何给图片打马赛克

接下来写addCanvas方法

function addCanvas() {let bt = document.querySelector('button')        let img = new Image();//1.准备赋值复制一份图片        img.src = './download.jpg';         img.onload = function() { //2.待图片加载完成            let width = this.width            let height = this.heightlet canvas = document.createElement('canvas') //3.创建画布let ctx = canvas.getContext("2d");  //4.获得该画布的内容        canvas.setAttribute('width', width)  //5.为了统一,设置画布的宽高为图片的宽高        canvas.setAttribute('height', height)               ctx.drawImage(this, 0, 0, width, height);  //5.在画布上绘制该图片            document.body.insertBefore(canvas, bt) //5.把canvas插入到按钮前面        }    }

成功在画布上得到图片:

js如何给图片打马赛克

嗯,我们已经成功走出了成功的一小步,接下来是干什么呢?…嗯,我们需要利用原生的onmouseuponmousedown事件,代表我们按下鼠标这个过程,那么这两个事件添加到哪呢?

没错,既然我们要在canvas上进行马赛克操作,那我们必然要给canvas元素添加这两个事件

考虑到我们创建canvas的过程复杂了一点,我们做一个模块封装吧!

function addCanvas() {        let bt = document.querySelector('button')        let img = new Image();        img.src = './download.jpg'; //这里放自己的图片        img.onload = function() {            let width = this.width            let height = this.height            let {                canvas,                ctx            } = createCanvasAndCtx(width, height)  //对象解构接收canvas和ctx            ctx.drawImage(this, 0, 0, width, height);            document.body.insertBefore(canvas, bt)        }    }    function createCanvasAndCtx(width, height) {        let canvas = document.createElement('canvas')        canvas.setAttribute('width', width)        canvas.setAttribute('height', height)        canvas.setAttribute('onmouseout', 'end()') //修补鼠标不在canvas上离开的补丁        canvas.setAttribute('onmousedown', 'start()')  //添加鼠标按下        canvas.setAttribute('onmouseup', 'end()')//添加鼠标弹起        let ctx = canvas.getContext("2d");        return {            canvas,            ctx        }    }function start() {            let canvas = document.querySelector('canvas')            canvas.onmousemove = () => {                console.log('你按下了并移动了鼠标')            }        }        function end() {            let canvas = document.querySelector('canvas')            canvas.onmousemove = null        }

测试一下我们的start()end()是否生效了

js如何给图片打马赛克

嗯,目前来看,我们的代码依然如我们所愿的正常工作

接下来的挑战更加严峻,我们需要去获取像素和处理像素,让我们再重写start()函数

function start() {    let img = document.querySelector('img')    let canvas = document.querySelector('canvas')    let ctx = canvas.getContext("2d");    imgData = ctx.getImageData(0, 0, img.clientWidth, img.clientHeight);    canvas.onmousemove = (e) => {        let w = imgData.width; //1.获取图片宽高        let h = imgData.height;        //马赛克的程度,数字越大越模糊        let num = 10;        //获取鼠标当前所在的像素RGBA        let color = getXY(imgData, e.offsetX, e.offsetY);        for (let k = 0; k < num; k++) {            for (let l = 0; l < num; l++) {                //设置imgData上坐标为(e.offsetX + l, e.offsetY + k)的的颜色                setXY(imgData, e.offsetX + l, e.offsetY + k, color);            }        }        //更新canvas数据        ctx.putImageData(imgData, 0, 0);    }}//这里为你提供了setXY和getXY两个函数,如果你有兴趣,可以去研究获取的原理function setXY(obj, x, y, color) {    var w = obj.width;    var h = obj.height;    var d = obj.data;    obj.data[4 * (y * w + x)] = color[0];    obj.data[4 * (y * w + x) + 1] = color[1];    obj.data[4 * (y * w + x) + 2] = color[2];    obj.data[4 * (y * w + x) + 3] = color[3];}function getXY(obj, x, y) {    var w = obj.width;    var h = obj.height;    var d = obj.data;    var color = [];    color[0] = obj.data[4 * (y * w + x)];    color[1] = obj.data[4 * (y * w + x) + 1];    color[2] = obj.data[4 * (y * w + x) + 2];    color[3] = obj.data[4 * (y * w + x) + 3];    return color;}

嗯,我们离成功不远拉,最后一步就是生成图片

好在canavs给我们提供了直接的方法,可以直接将画布导出为Base64编码的图片:

function generateImg() {    let canvas = document.querySelector('canvas')    var newImg = new Image();    newImg.src = canvas.toDataURL("image/png");    document.body.insertBefore(newImg, canvas)}

最终效果:

js如何给图片打马赛克

是不是无比轻松呢~,来看看你手写的代码是否和下面一样叭:

完整代码

<!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">    <title>Document</title></head><body>    <body>        <img src="./download.jpg">        <button onclick="addCanvas()">生成Canvas</button>        <button onclick="generateImg()">生成图片</button>    </body>    <script>        function addCanvas() {            let bt = document.querySelector('button')            let img = new Image();            img.src = './download.jpg'; //这里放自己的图片            img.onload = function() {                let width = this.width                let height = this.height                let {                    canvas,                    ctx                } = createCanvasAndCtx(width, height)                ctx.drawImage(this, 0, 0, width, height);                document.body.insertBefore(canvas, bt)            }        }        function createCanvasAndCtx(width, height) {            let canvas = document.createElement('canvas')            canvas.setAttribute('width', width)            canvas.setAttribute('height', height)            canvas.setAttribute('onmouseout', 'end()')            canvas.setAttribute('onmousedown', 'start()')            canvas.setAttribute('onmouseup', 'end()')            let ctx = canvas.getContext("2d");            return {                canvas,                ctx            }        }        function start() {            let img = document.querySelector('img')            let canvas = document.querySelector('canvas')            let ctx = canvas.getContext("2d");            imgData = ctx.getImageData(0, 0, img.clientWidth, img.clientHeight);            canvas.onmousemove = (e) => {                let w = imgData.width; //1.获取图片宽高                let h = imgData.height;                //马赛克的程度,数字越大越模糊                let num = 10;                //获取鼠标当前所在的像素RGBA                let color = getXY(imgData, e.offsetX, e.offsetY);                for (let k = 0; k < num; k++) {                    for (let l = 0; l < num; l++) {                        //设置imgData上坐标为(e.offsetX + l, e.offsetY + k)的的颜色                        setXY(imgData, e.offsetX + l, e.offsetY + k, color);                    }                }                //更新canvas数据                ctx.putImageData(imgData, 0, 0);            }        }        function generateImg() {            let canvas = document.querySelector('canvas')            var newImg = new Image();            newImg.src = canvas.toDataURL("image/png");            document.body.insertBefore(newImg, canvas)        }        function setXY(obj, x, y, color) {            var w = obj.width;            var h = obj.height;            var d = obj.data;            obj.data[4 * (y * w + x)] = color[0];            obj.data[4 * (y * w + x) + 1] = color[1];            obj.data[4 * (y * w + x) + 2] = color[2];            obj.data[4 * (y * w + x) + 3] = color[3];        }        function getXY(obj, x, y) {            var w = obj.width;            var h = obj.height;            var d = obj.data;            var color = [];            color[0] = obj.data[4 * (y * w + x)];            color[1] = obj.data[4 * (y * w + x) + 1];            color[2] = obj.data[4 * (y * w + x) + 2];            color[3] = obj.data[4 * (y * w + x) + 3];            return color;        }        function end() {            let canvas = document.querySelector('canvas')            canvas.onmousemove = null        }    </script></body></html>

当然,你可以做更多创作,比如上面打的马赛克是正方形的,你可以利用你的数学知识让其变为圆形,以圆心为鼠标中心扩散

你也可以选择完善一些过程,例如马赛克位置打错了,可以选择将画布清空然后重新开始~
或者做一些善后处理,导出图片后隐藏canvas画布

感谢各位的阅读!关于“js如何给图片打马赛克”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: js如何给图片打马赛克

本文链接: https://lsjlt.com/news/276979.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • js如何给图片打马赛克
    这篇文章给大家分享的是有关js如何给图片打马赛克的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。效果演示Canvas简介这个 HTML 元素是为了客户端矢量图形而设计的。它自己没有行为,但却把一个绘图 API 展现...
    99+
    2023-06-15
  • js给图片打马赛克的方法示例
    本文主要主要介绍了js给图片打马赛克的方法示例,分享给大家,具体如下: 效果演示 Canvas简介 这个 HTML 元素是为了客户端矢量图形而设计的。它自己没有行为,但却把一个绘...
    99+
    2024-04-02
  • canvas如何给图片加马赛克
    本篇内容介绍了“canvas如何给图片加马赛克”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!@charset "UTF-8";.markdo...
    99+
    2023-07-05
  • 手把手教你怎么给图片加马赛克
    @charset "UTF-8";.markdown-body{word-break:break-word;line-height:1.75;font-weight:400;font-size:15px;overflow-x:hidden;...
    99+
    2023-05-14
    图片 马赛克 前端 JavaScript
  • Python如何实现多张图片合成一张马赛克图片
    这篇文章将为大家详细讲解有关Python如何实现多张图片合成一张马赛克图片,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。图片素材4K高清原图开发环境Python 3.6Pycharm实现代码先导入所需模块...
    99+
    2023-06-22
  • Python实现多张图片合成一张马赛克图片
    目录前言开发环境实现代码先导入所需模块读取图片文件读取所有源图片并计算对应颜色平均值合法图像列表平均颜色列表遍历主函数模块调用执行完整效果前言 最近有网友私信我,问如何把多张图片合成...
    99+
    2024-04-02
  • JavaCV如何实现照片马赛克效果
    小编给大家分享一下JavaCV如何实现照片马赛克效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!准备工作我们先引入 JavaCV 的依赖库  <dependency>  ...
    99+
    2023-06-28
  • 如何使用CSS实现图片马赛克风格化效果
    这篇文章主要介绍如何使用CSS实现图片马赛克风格化效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、image-rendering 介绍CSS 中有一个有趣的特性叫 image-...
    99+
    2024-04-02
  • 基于Html5 canvas如何实现裁剪图片和马赛克功能
    这篇文章主要介绍了基于Html5 canvas如何实现裁剪图片和马赛克功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.核心功能  此组件功能包含:    图片裁剪(裁剪...
    99+
    2023-06-09
  • 怎么利用SVG实现图片马赛克效果
    这篇文章主要讲解了“怎么利用SVG实现图片马赛克效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么利用SVG实现图片马赛克效果”吧!何为 image-r...
    99+
    2024-04-02
  • windows中inpaint如何去马赛克
    本篇内容介绍了“windows中inpaint如何去马赛克”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-12-09
    windows inpaint
  • 使用canvas怎么实现一个图片马赛克效果
    本篇文章为大家展示了使用canvas怎么实现一个图片马赛克效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. 原生canvas实现用到的API1) getContext(contextID) -...
    99+
    2023-06-09
  • Opencv 马赛克和毛玻璃效果与图片融合的实现
    目录1.马赛克效果2. 毛玻璃效果3. 图片的融合算法实现1.马赛克效果 马赛克的基本原理就是,用某一个区域的某一个像素点替代这个区域所有的像素点,从而导致图片出现模糊的效果,如下...
    99+
    2024-04-02
  • 怎么实现Opencv马赛克和毛玻璃效果与图片融合
    这篇文章主要介绍“怎么实现Opencv马赛克和毛玻璃效果与图片融合”,在日常操作中,相信很多人在怎么实现Opencv马赛克和毛玻璃效果与图片融合问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么实现Openc...
    99+
    2023-06-25
  • C++实现将图片转换为马赛克效果的示例代码
    这个程序将图片转换为马赛克效果。 算法原理:求出每个小方块内所有像素的颜色平均值,然后用来设置为该小方块的颜色。依次处理每个小方块,即可实现马赛克效果。 完整代码如下 // 程序名称...
    99+
    2023-01-14
    C++图片转马赛克 C++ 图片 马赛克
  • ios如何给UIView设置图片
    这篇文章将为大家详细讲解有关ios如何给UIView设置图片,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。给UIView设置图片UIImage *image&n...
    99+
    2024-04-02
  • html如何给图片设置链接
    这篇文章主要介绍html如何给图片设置链接,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!html是什么html的全称为超文本标记语言,它是一种标记语言,包含了一系列标签.通过这些标签可以将网络上的文档格式统一,使分散...
    99+
    2023-06-15
  • 电脑如何打印图片
    本篇内容主要讲解“电脑如何打印图片”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“电脑如何打印图片”吧!电脑打印图片方法:右击图片选择“打印”。 选择自己的打印机进行打印。 选择需要的纸张大小。 ...
    99+
    2023-07-01
  • 如何使用python给图片加水印
    这篇文章主要介绍如何使用python给图片加水印,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!方式一:叠加文字水印最简单的一种方式是,在图片上绘制半透明文本来实现水印效果。主要用到Figure.text函数参数类型说...
    99+
    2023-06-15
  • p5.js如何实现图片加载
    这篇文章主要为大家展示了“p5.js如何实现图片加载”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“p5.js如何实现图片加载”这篇文章吧。一、preload()...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作