Canvas + JavaScript 制作图片粒子效果

发布时间 - 2026-01-10 22:55:36    点击率:

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

左侧图片为源图,右侧图片为粒子效果图。该效果是在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代码:

<!DOCTYPE html>
<html>
<head lang="en">
 <meta charset="UTF-8">
 <title></title>
</head>
<body>
<canvas id="myCanvas" width="600" height="400" style="background:#000">浏览器不支持canvas</canvas>
</body>
<script type="text/javascript">
 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<=200;j++){
  pos=[(i-1)*200+(j-1)]*4; //取得像素位置
  if(data[pos]>=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);
 }
 }
</script>
</html>

上面如果不理解, 对照代码运行一下试试理解吧:

可惜本人数学不好,算法不会。不能为粒子加上炫酷的动态效果~~其实可以找一些算法让粒子动起来的,有兴趣可以做做看~

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# canvas粒子效果  # canvas  # 图片粒子效果  # 使用3D引擎threeJS实现星空粒子移动效果  # THREE.JS入门教程(4)创建粒子系统  # 原生JS+HTML5实现跟随鼠标一起流动的粒子动画效果  # 基于Particles.js制作超炫粒子动态背景效果(仿知乎)  # 用JavaScript玩转游戏物理(一)运动学模拟与粒子系统  # javascript转换静态图片  # 增加粒子动画效果  # JS库particles.js创建超炫背景粒子插件(附源码下载)  # 基于three.js实现的3D粒子动效实例代码  # JavaScript实现鼠标移动粒子跟随效果  # js canvas实现随机粒子特效  # 是有  # 返回值  # 是一个  # 整型  # 是在  # 第一个  # 它是  # 第二个  # 有兴趣  # 考虑到  # 不支持  # 为例  # 看一下  # 能为  # 转换成  # 时要  # 都为  # 不理解  # 上图  # 象中 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何快速打造个性化非模板自助建站?  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  米侠浏览器网页背景异常怎么办 米侠显示修复  奇安信“盘古石”团队突破 iOS 26.1 提权  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  Python高阶函数应用_函数作为参数说明【指导】  如何在Windows虚拟主机上快速搭建网站?  Laravel怎么调用外部API_Laravel Http Client客户端使用  在Oracle关闭情况下如何修改spfile的参数  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  Laravel如何使用withoutEvents方法临时禁用模型事件  Android GridView 滑动条设置一直显示状态(推荐)  移动端脚本框架Hammer.js  Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程  如何在万网利用已有域名快速建站?  laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  魔毅自助建站系统:模板定制与SEO优化一键生成指南  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  免费网站制作appp,免费制作app哪个平台好?  如何在Windows环境下新建FTP站点并设置权限?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  轻松掌握MySQL函数中的last_insert_id()  Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  JavaScript如何实现倒计时_时间函数如何精确控制  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  使用Dockerfile构建java web环境  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  Laravel如何创建自定义中间件?(Middleware代码示例)  网站制作软件免费下载安装,有哪些免费下载的软件网站?  如何彻底删除建站之星生成的Banner?  在线教育网站制作平台,山西立德教育官网?  大连网站制作公司哪家好一点,大连买房网站哪个好?  js实现点击每个li节点,都弹出其文本值及修改  phpredis提高消息队列的实时性方法(推荐)  Laravel如何实现数据库事务?(DB Facade示例)  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  长沙企业网站制作哪家好,长沙水业集团官方网站?  Laravel如何创建自定义Artisan命令?(代码示例)  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  Python进程池调度策略_任务分发说明【指导】  百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何做网站制作流程,*游戏网站怎么搭建?