讲述Canvas结合JavaScript实现图片特效

我们都知道canvas是html5中的,canvas可以做出很多特效等神奇的东西,而javascript当然也可以,但是canvas结合javascript来实现图片特效你玩过嘛,没有的话那么我们一起来看看吧!

首先看一下源图和转换成粒子效果的对比图:

4a471486525612.png

LWE0CVRA7B9}AGD]{E6C`67.png

左侧图片为源图,右侧图片为粒子效果图。该效果是在Canvas画布上制作的。将图片制作成粒子效果相对而言是比较简单的。重点了解两个知识点即可

立即学习“Java免费学习笔记(深入)”;

1、图片是通过image对象形式绘制在画布上的,然后使用Canvas的getImageData接口,获取图像的像素信息。

var imageData=ctx.getImageData(x, y, width, height);

登录后复制

参数说明:x,y为画布上的x和y坐标

width,height为获取指定区域图像的信息

返回值说明:imageData为返回值,它是一个对象,包含三个属性

imageData={    data:Unit8ClampedArray[10000] //一个包含图片区域内每个像素点的RGBA的整型数据信息    height:200   //读取的图片像素信息区域高度    width:200   //读取的图片像素信息区域宽度}

登录后复制

2、了解像素区域数据的排布说明,以上获取的图片数据像素信息(imageData对象中的data属性)为RGBA整型的一维数组数据。一个像素是有4个值(R,G,B,A)组成的。也就是说,数组信息每四个为一个像素点。因此,有以下规则,

第一个像素信息为:RGBA(data[0],data[1],data[2],data[3])

      第二个像素信息为:RGBA(data[4],data[5],data[6],data[7])

      …..

      第N个像素信息为: RGBA(data[(n-1)*4],data[(n-1)*4+1],data[(n-1)*4+2],data[(n-1)*4+3])

      …..

另外,像素区域既然是一个区域,它是有宽和高的。上面的推算公式适合单独一行使用定位一个像素点。所以计算像素点时要考虑到在整个图像区域内定位:

以上图为例。图像的宽和高都为200,如果按照每一个像素为一行一列时。则该图像共有200行,200列。所以要取得 i 行第 j 列的像素初始位置信息为:

var pos =[( i-1 )*200]+( j-1 )]*4;

登录后复制

其中,公式中的 i 表示行数,j 表示列数。200为图像的宽度。

demo代码:

nbsp;html>        浏览器不支持canvas    var canvas=document.getElementById("myCanvas");    var ctx=canvas.getContext("2d");    var image = new Image();    image.src='/WebWorkspace/EchartDemo/images/star.png';    var pixels=[];  //存储像素数据    var imageData;    image.onload=function(){        ctx.drawImage(image,200,100,200,200);        imageData=ctx.getImageData(200,100,200,200);    //获取图表像素信息        getPixels();    //获取所有像素        drawPic();  //绘制图像    };    function getPixels(){        var pos=0;        var data=imageData.data;    //RGBA的一维数组数据        //源图像的高度和宽度为200px        for(var i=1;i<=200;i++){            for(var j=1;j=0){                    var pixel={                        x:200+j+Math.random()*20, //重新设置每个像素的位置信息                        y:100+i+Math.random()*20, //重新设置每个像素的位置信息                        fillStyle:'rgba('+data[pos]+','+(data[pos+1])+','+(data[pos+2])+','+(data[pos+3])+')'                    }                    pixels.push(pixel);                }            }        }    }    function drawPic(){        var canvas=document.getElementById("myCanvas");        var ctx=canvas.getContext("2d");        ctx.clearRect(0,0,600,400);        var len=pixels.length,curr_pixel=null;        for(var i=0;i<len;i++){            curr_pixel=pixels[i];            ctx.fillStyle=curr_pixel.fillStyle;            ctx.fillRect(curr_pixel.x,curr_pixel.y,1,1);        }    }

登录后复制

上面如果不理解, 对照代码运行一下试试理解吧,切记图片地址要改哦!不然会报错的

类似阅读:

利用Canvas对图片进行处理的方法

Canvas实现炫丽的粒子运动效果

以上就是讲述Canvas结合JavaScript实现图片特效的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2784566.html

(0)
上一篇 2025年3月8日 17:07:59
下一篇 2025年3月8日 17:08:09

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • js实现input输入框点击变大缩小

    本文主要和大家分享js实现input输入框点击变大缩小的实例代码,希望能帮助到大家。 一、input输入框点击变大缩小的js代码 html中 input[type='text'] {width: 100px;height…

    编程技术 2025年3月8日
    200
  • js中的正则表达式大全

    这次给大家带来js中的正则表达式大全,在js中使用正则表达式的注意事项有哪些,下面就是实战案例,一起来看一下。 1、什么是正则? 正则也叫做规则,让计算机能够读懂人类的规则(正则都是操作字符串的) 2、什么是正则表达式? 正则表达式是由一个…

    编程技术 2025年3月8日
    200
  • js正则表达式的10个应用实例

    js中正则表达式的10个应用实例 1、找重复项最多的字符和个数 [html] view plain copy var str = 'sassdfdfffdasdffffffsdsdddsss'; var arr = st…

    编程技术 2025年3月8日
    200
  • js关于BOM操作的知识整理

    这次给大家带来js关于bom操作的知识整理,js中的bom操作注意事项有哪些,下面就是实战案例,一起来看一下。 一、什么是BOM? BOM:Browser Object Model 是浏览器对象模型,浏览器对象模型提供了独立与内容的、可以与…

    2025年3月8日
    200
  • Vue.js的2.0后台系统实战案例

    这次给大家带来vue.js的2.0后台系统实战案例,vue.js2.0后台系统实战的注意事项有哪些,下面就是实战案例,一起来看一下。 朋友最近要做个自己用的OA来练练手(PS,那逼一直想创业),找我和他一起做,由于最近时间有限,就帮他写个框…

    编程技术 2025年3月8日
    200
  • Vuejs webp支持图片的插件开发

    这次给大家带来vuejs webp支持图片的插件开发,vuejs webp插件开发的注意事项有哪些,下面就是实战案例,一起来看一下。 本人已经使用vue.js半年多了,在做一些Html5页面的时候发现很多页面都是图片组成的,如果能有效的压缩…

    2025年3月8日
    200
  • JavaScript实现禁止微信浏览器下拉回弹效果

    这篇文章主要为大家详细介绍了javascript禁止微信浏览器下拉回弹效果的方法,具有一定的参考和学习javascript的价值,对javascript感兴趣的小伙伴们可以参考一下本篇文章 本文实例为大家分享了JavaScript禁止微信浏…

    编程技术 2025年3月8日
    200
  • Angularjs如何实现mvvm式选项卡?案列+代码

    我们知道,选项卡是现代web网页中最常用的效果之一,这次给大家带来angularjs如何实现mvvm式选项卡?案列+代码,下面就是实战案例,一起来看一下。 本文重点是用angularjs这个非常火mvvm框架,实现选项卡效果。在此之前,先搬…

    2025年3月8日
    200
  • Angularjs的promise对象详解

    这次给大家带来angularjs的promise对象详解,使用angularjs的promise对象时注意事项有哪些,下面就是实战案例,一起来看一下。 promise是什么?要了解它,需要先从我们面临的问题开始讲起。在操作ajax异步请求时…

    编程技术 2025年3月8日
    200
  • JS可以截取video的标签视频缩略图吗?

    这次给大家带来js可以截取video的标签视频缩略图吗?,js截取video的标签视频缩略图的注意事项有哪些,下面就是实战案例,一起来看一下。 JavaScript截取video标签视频缩略图,前几天做个小项目以瀑布流加载MP4视频,一个页…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论