【JavaScript】explode动画
这是一个js实现的粒子聚合文字或图片的动画特效

部分程序如下
n.container = n.container[0] || n.container; /*有且仅有一个container*/
var width = n.params.width;
var height = n.params.height;
var wWidth = document.body.clientWidth;
var wHeight = document.body.clientHeight;
n.container.width = width;
n.container.height = height;
var ctx = n.container.getContext('2d');
var c = document.createElement('canvas');
var ct = c.getContext('2d'); /*用于绘制图片或文字*/
var items = [];
var picture = null;
var requestId = null;
var total = 0;
var getRandom = function(max, min) {
min = arguments[1] || 0;
return Math.floor(Math.random() * (max - min + 1) + min); /*取min和max之间的随机数*/
};
function cutSlice() {/*cutSlice()方法,实现粒子动画,让其往最终位置运动*/
ctx.clearRect(0, 0, n.container.width, n.container.height);
for(var i = 0; i < c.width * c.height; i++) {
var item = items[i];
var targetX = item.targetX;
var targetY = item.targetY;
var currentX = item.currentX;
var currentY = item.currentY;
var ax = false;
var ay = false;
if(!item.isLock) {
if(Math.abs(targetX - currentX) <= .5) {
item.currentX = targetX;
ax = true;
} else {
item.currentX += (targetX - currentX) * item.ax;
};
if(Math.abs(targetY - currentY) <= .5) {
item.currentY = targetY;
ay = true;
} else {
item.currentY += (targetY - currentY) * item.ay;
};
if(ax && ay) {/*只有ax和ay同时到达终点时,total才会减1*/
total--;
item.isLock = true;
}
};
var ix = item.currentX;
var iy = item.currentY;
ctx.putImageData(item.data, ix, iy); /*putImageData() 方法将图像数据(从指定的 ImageData 对象)放回画布上。*/
};
if(total > 0) {
requestId = requestAnimationFrame(cutSlice); /*不用设置间隔,反复调用*/
} else {
cancelAnimationFrame(requestId);
};
}
function Item(data, targetX, targetY, currentX, currentY) {/*创建一个Item构造函数,用来放置每一个粒子*/
this.data = data;
this.targetX = targetX; /*聚合的最终位置*/
this.targetY = targetY;
this.currentX = currentX;/*当前位置*/
this.currentY = currentY;
this.ax = .13 - Math.random() * .06; /*ax和ay分别表示运动速度*/
this.ay = .16 - Math.random() * .08;
}
function drawCanvas() {
if(n.params.type == 2) { /*针对图片*/
picture = new Image();
picture.crossOrigin = "";
picture.onload = function() {
var pw = picture.width;
var ph = picture.height;
c.width = pw; /*设置canvas的宽度*/
c.height = ph;
ct.drawImage(picture, 0, 0, pw, ph, 0, 0, pw, ph); /*把图像中的某个区域绘制到上下文中,源图像(起点和宽高),上下文中的起点和宽高*/
draw(pw, ph);
};
picture.src = n.params.img;
} else { /*针对文字*/
var word = n.params.text;
ct.font = '60px Arial'; /*这里指定用于测文本宽度*/
var w = ct.measureText(word).width; /*测文本宽度*/
var h = 100;
c.width = w;
c.height = h;
ct.fillStyle = 'deepskyblue';
ct.font = '60px Arial'; /*这里指定用于绘制文本,应与之前设置保持一致*/
// ct.textAlign = 'center';
ct.textBaseline = 'middle';
ct.fillText(word, 0, 50); /*绘制文本,这里为什么没有直接绘制上去?而要调用draw???*/
draw(w, h);
}
function draw(pw, ph) {/*draw 方法用来分解粒子,先分成cols 列和rows 行,每一个粒子高度都为1,然后用
getImageData() 来获取ImageData对象,然后创建新的Item实例,然后添加到items数组中。*/
var w = 1;
var h = 1;
var cols = Math.floor(pw / w);/*图片或文字的宽度高度*/
var rows = Math.floor(ph / h);
for(var i = 0; i < c.width * c.height; i++) {
var x = Math.floor(i % cols); /*通过xy找到每一行的所有元素(0,0)(1,0)...(0,1)(1,1)(2,1)*/
var y = Math.floor(i / cols);
var data = ct.getImageData(x * w, y * h, w, h);/* 文字也能获取??拷贝!取得原始图像数据,要取得取数据的画面区域的xy坐标以及该区域的像素宽度和高度,这里每次取1*1像素*/
var vx = getRandom(300, -300);
var vy = getRandom(500, -500); /*扩大范围,使图片周围也有粒子*/
var item = new Item(data, x, y, x + vx, y + vy);
items.push(item);
};
total = items.length;
cutSlice();
}
}
【JavaScript】explode动画的更多相关文章
- JavaScript实现动画效果
说到JavaScript实现动画效果,不得不想到两个函数,setTimeout和setInterval. setTimeout的常用的使用方法为 setTimeout(callback, delay) ...
- 原生JavaScript中动画与特效的实现原理
现如今,许多页面上均有一些动画效果.适当的动画效果可以在一定程度上提高页面的美观度,具有提示效果的动画可以增强页面的易用性. 实现页面动画的途径一般有两种. 一种是通过操作JavaScript间接操作 ...
- javascript帧动画
前面的话 帧动画就是在“连续的关键帧”中分解动画动作,也就是在时间轴的每帧上逐帧绘制不同的内容,使其连续播放而成的动画.由于是一帧一帧的画,所以帧动画具有非常大的灵活性,几乎可以表现任何想表现的内容. ...
- javascript之动画特效
JavaScript的动画用的最多的3个api就是setInterval().setTimeout()和requestAnimationFrame()
- "Javascript高性能动画与页面渲染"笔记
前言:好久没翻阅我的gmail邮箱了,午休时就打开看了一下,看到InfoQ推荐的一篇名为“Javascript高性能动画与页面渲染”文章,粗略的看了一下,很赞!讲的很详细,对好些细节讲的都很好,很通俗 ...
- Javascript高性能动画与页面渲染
转自:http://www.infoq.com/cn/articles/javascript-high-performance-animation-and-page-rendering No setT ...
- JavaScript之动画2
在JavaScript动画中,我们调用setInterval函数(setInterval动作的作用是在播放动画的时,每隔一定时间就调用函数,方法或对象),值得注意的是:setInterval它设置的时 ...
- Javascript - Jquery - 动画
动画(Dynamic) JQuery动画必须是在标准文档下使用 否则可能引起动画时抖动或其它不可预知的结果,标准文档格式: <!DOCTYPE html PUBLIC "-//W3 ...
- [转]Javascript高性能动画与页面渲染
No setTimeout, No setInterval 作者 李光毅 发布于 2014年4月30日 如果你不得不使用setTimeout或者setInterval来实现动画,那么原因只能是你需要精 ...
随机推荐
- 如鹏网学习笔记(十)DOM
DOM笔记一.DOM简介 Document Object Model 文档对象模型 DOM的节点树模型:整个文档按照从大到小的节点划分,每一个内容都算作一个节点 DOM API 编程接口 可以用来操作 ...
- js 千分位符号 正则方法
function toThousands(num) { return (num || 0).toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,');}
- 撩课-Java每天10道面试题第6天
51.HashMap的实现原理 HashMap的主干是一个Entry数组. Entry是HashMap的基本组成单元, 每一个Entry包含一个key-value键值对. HashMap基于hashi ...
- 【SSH网上商城项目实战13】Struts2实现文件上传功能
转自:https://blog.csdn.net/eson_15/article/details/51366384 上一节我们做完了添加和更新商品的功能,这两个部分里有涉及到商品图片的上传,并没有详细 ...
- Android Studio下载/更新SDK
今天安装配置Android Studio的时候,用SDK Manager下载SDK的时候只显示了一个7.0,别的都刷新不出来(被墙了).去网上搜索怎么解决,发现很多帖子的方法已经过时了(跟现在的AS版 ...
- code.google.com certificate error: certificate is for www.google.com
有时候我们会碰到下面错误:code.google.com certificate error: certificate is for www.google.com,类似如下: D:\>go ge ...
- HDU 4248 A Famous Stone Collector 组合数学dp ****
A Famous Stone Collector Time Limit: 30000/15000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- Spring与Web
一.定义页面及Servlet 在jsp页面加入以下,避免乱码 <meta charset="utf-8"> <body> <form action=& ...
- js串结构
朴素匹配算法 //S 主串 T 模式串 //匹配失败,回溯 i = i - j + 1 j = 0 //匹配成功,返回位置 i - j function indexOf(S,T,pos = 0){ l ...
- python-Django框架url分发实现返回时间
1.创建Django工程 再newproject中选择Django工程,在Location中输入建立的项目文件夹名称,Application name中输入要建立的app名称后电机Create. 2. ...