博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Canvas + JavaScript 制作图片粒子效果
阅读量:6825 次
发布时间:2019-06-26

本文共 1062 字,大约阅读时间需要 3 分钟。

 

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

     

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

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代码:

  
浏览器不支持canvas

转载于:https://www.cnblogs.com/suchuanzhong/p/6391135.html

你可能感兴趣的文章
分形树的绘制
查看>>
loadrunner请求中有汉字 如何编码
查看>>
java数据结构 • 面向对象 • 异常 • 随机数·时间
查看>>
springmvc 实现pc端手机端适配(同一个请求根据不同客户端展示不同界面)
查看>>
BTree和B+Tree详解
查看>>
VS2005工程迁移到Eclipse CDT
查看>>
Linux高端内存映射(上)【转】
查看>>
usb_control_msg参数详解【转】
查看>>
8086汇编指令速查手册
查看>>
j2EE web.xml中的url-pattern的映射规则
查看>>
设计模式之单例模式
查看>>
获取客户端ip地址
查看>>
sessionid如何产生?由谁产生?保存在哪里?
查看>>
oracle 监听服务异常
查看>>
网络流——最大流Dinic算法
查看>>
下面的div浮动上来了
查看>>
程序员生存定律
查看>>
windows 下搭建 apache + php52 + postgreSQL7/8/9环境
查看>>
python正则表达式
查看>>
分布式系统的面试题3
查看>>