使用 HTML5 Canvas 制作水波纹效果点击图片就会触发_html5教程技巧
2015-01-03 22:19:44
[小 大]
已经帮助:人解决问题
这篇文章会介绍使用 JavaScript 实现水波纹效果。水波效果以图片为背景,点击图片任意位置都会触发,附源码下载,喜欢的朋友可以参考下
今天,我们继续分享 JavaScript 实现的效果例子,这篇文章会介绍使用 JavaScript 实现水波纹效果。水波效果以图片为背景,点击图片任意位置都会触发。有时候,我们使用普通的 Javascript 就可以创建一个很有趣的解决功能。 cbnHTML5中文学习网 - HTML5先行者学习网
cbnHTML5中文学习网 - HTML5先行者学习网
源码下载cbnHTML5中文学习网 - HTML5先行者学习网
cbnHTML5中文学习网 - HTML5先行者学习网
Step 1. HTML cbnHTML5中文学习网 - HTML5先行者学习网
cbnHTML5中文学习网 - HTML5先行者学习网
和以前一样,首先是 HTML 代码: cbnHTML5中文学习网 - HTML5先行者学习网
cbnHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html> cbnHTML5中文学习网 - HTML5先行者学习网
<html> cbnHTML5中文学习网 - HTML5先行者学习网
<head> cbnHTML5中文学习网 - HTML5先行者学习网
<meta charset=utf-8 /> cbnHTML5中文学习网 - HTML5先行者学习网
<title>Water drops effect</title> cbnHTML5中文学习网 - HTML5先行者学习网
<link rel="stylesheet" href="css/main.css" type="text/css" /> cbnHTML5中文学习网 - HTML5先行者学习网
<script src="js/vector2d.js" type="text/javascript" charset="utf-8"></script> cbnHTML5中文学习网 - HTML5先行者学习网
<script src="js/waterfall.js" type="text/javascript" charset="utf-8"></script> cbnHTML5中文学习网 - HTML5先行者学习网
</head> cbnHTML5中文学习网 - HTML5先行者学习网
<body> cbnHTML5中文学习网 - HTML5先行者学习网
<div class="example"> cbnHTML5中文学习网 - HTML5先行者学习网
<h3><a href="#">Water drops effect</a></h3> cbnHTML5中文学习网 - HTML5先行者学习网
<canvas id="water">HTML5 compliant browser required</canvas> cbnHTML5中文学习网 - HTML5先行者学习网
<div id="switcher"> cbnHTML5中文学习网 - HTML5先行者学习网
<img onclick='watereff.changePicture(this.src);' src="data_images/underwater1.jpg" /> cbnHTML5中文学习网 - HTML5先行者学习网
<img onclick='watereff.changePicture(this.src);' src="data_images/underwater2.jpg" /> cbnHTML5中文学习网 - HTML5先行者学习网
</div> cbnHTML5中文学习网 - HTML5先行者学习网
<div id="fps"></div> cbnHTML5中文学习网 - HTML5先行者学习网
</div> cbnHTML5中文学习网 - HTML5先行者学习网
</body> cbnHTML5中文学习网 - HTML5先行者学习网
</html> cbnHTML5中文学习网 - HTML5先行者学习网
cbnHTML5中文学习网 - HTML5先行者学习网Step 2. CSS cbnHTML5中文学习网 - HTML5先行者学习网cbnHTML5中文学习网 - HTML5先行者学习网这是用到的 CSS 代码:
cbnHTML5中文学习网 - HTML5先行者学习网 cbnHTML5中文学习网 - HTML5先行者学习网
body{background:#eee;margin:0;padding:0} cbnHTML5中文学习网 - HTML5先行者学习网
.example{background:#FFF;width:600px;border:1px #000 solid;margin:20px auto;padding:15px;-moz-border-radius: 3px;-webkit-border-radius: 3px} cbnHTML5中文学习网 - HTML5先行者学习网
#water { cbnHTML5中文学习网 - HTML5先行者学习网
width:500px; cbnHTML5中文学习网 - HTML5先行者学习网
height:400px; cbnHTML5中文学习网 - HTML5先行者学习网
display: block; cbnHTML5中文学习网 - HTML5先行者学习网
margin:0px auto; cbnHTML5中文学习网 - HTML5先行者学习网
cursor:pointer; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
#switcher { cbnHTML5中文学习网 - HTML5先行者学习网
text-align:center; cbnHTML5中文学习网 - HTML5先行者学习网
overflow:hidden; cbnHTML5中文学习网 - HTML5先行者学习网
margin:15px; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
#switcher img { cbnHTML5中文学习网 - HTML5先行者学习网
width:160px; cbnHTML5中文学习网 - HTML5先行者学习网
height:120px; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
cbnHTML5中文学习网 - HTML5先行者学习网Step 3. JS cbnHTML5中文学习网 - HTML5先行者学习网cbnHTML5中文学习网 - HTML5先行者学习网下面是主要的 JavaScript 代码:
cbnHTML5中文学习网 - HTML5先行者学习网 cbnHTML5中文学习网 - HTML5先行者学习网
function drop(x, y, damping, shading, refraction, ctx, screenWidth, screenHeight){ cbnHTML5中文学习网 - HTML5先行者学习网
this.x = x; cbnHTML5中文学习网 - HTML5先行者学习网
this.y = y; cbnHTML5中文学习网 - HTML5先行者学习网
this.shading = shading; cbnHTML5中文学习网 - HTML5先行者学习网
this.refraction = refraction; cbnHTML5中文学习网 - HTML5先行者学习网
this.bufferSize = this.x * this.y; cbnHTML5中文学习网 - HTML5先行者学习网
this.damping = damping; cbnHTML5中文学习网 - HTML5先行者学习网
this.background = ctx.getImageData(0, 0, screenWidth, screenHeight).data; cbnHTML5中文学习网 - HTML5先行者学习网
this.imageData = ctx.getImageData(0, 0, screenWidth, screenHeight); cbnHTML5中文学习网 - HTML5先行者学习网
this.buffer1 = []; cbnHTML5中文学习网 - HTML5先行者学习网
this.buffer2 = []; cbnHTML5中文学习网 - HTML5先行者学习网
for (var i = 0; i < this.bufferSize; i++){ cbnHTML5中文学习网 - HTML5先行者学习网
this.buffer1.push(0); cbnHTML5中文学习网 - HTML5先行者学习网
this.buffer2.push(0); cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
this.update = function(){ cbnHTML5中文学习网 - HTML5先行者学习网
for (var i = this.x + 1, x = 1; i < this.bufferSize - this.x; i++, x++){ cbnHTML5中文学习网 - HTML5先行者学习网
if ((x < this.x)){ cbnHTML5中文学习网 - HTML5先行者学习网
this.buffer2[i] = ((this.buffer1[i - 1] + this.buffer1[i + 1] + this.buffer1[i - this.x] + this.buffer1[i + this.x]) / 2) - this.buffer2[i]; cbnHTML5中文学习网 - HTML5先行者学习网
this.buffer2[i] *= this.damping; cbnHTML5中文学习网 - HTML5先行者学习网
} else x = 0; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
var temp = this.buffer1; cbnHTML5中文学习网 - HTML5先行者学习网
this.buffer1 = this.buffer2; cbnHTML5中文学习网 - HTML5先行者学习网
this.buffer2 = temp; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
this.draw = function(ctx){ cbnHTML5中文学习网 - HTML5先行者学习网
var imageDataArray = this.imageData.data; cbnHTML5中文学习网 - HTML5先行者学习网
for (var i = this.x + 1, index = (this.x + 1) * 4; i < this.bufferSize - (1 + this.x); i++, index += 4){ cbnHTML5中文学习网 - HTML5先行者学习网
var xOffset = ~~(this.buffer1[i - 1] - this.buffer1[i + 1]); cbnHTML5中文学习网 - HTML5先行者学习网
var yOffset = ~~(this.buffer1[i - this.x] - this.buffer1[i + this.x]); cbnHTML5中文学习网 - HTML5先行者学习网
var shade = xOffset * this.shading; cbnHTML5中文学习网 - HTML5先行者学习网
var texture = index + (xOffset * this.refraction + yOffset * this.refraction * this.x) * 4; cbnHTML5中文学习网 - HTML5先行者学习网
imageDataArray[index] = this.background[texture] + shade; cbnHTML5中文学习网 - HTML5先行者学习网
imageDataArray[index + 1] = this.background[texture + 1] + shade; cbnHTML5中文学习网 - HTML5先行者学习网
imageDataArray[index + 2] = 50 + this.background[texture + 2] + shade; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
ctx.putImageData(this.imageData, 0, 0); cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
var fps = 0; cbnHTML5中文学习网 - HTML5先行者学习网
var watereff = { cbnHTML5中文学习网 - HTML5先行者学习网
// variables cbnHTML5中文学习网 - HTML5先行者学习网
timeStep : 20, cbnHTML5中文学习网 - HTML5先行者学习网
refractions : 2, cbnHTML5中文学习网 - HTML5先行者学习网
shading : 3, cbnHTML5中文学习网 - HTML5先行者学习网
damping : 0.99, cbnHTML5中文学习网 - HTML5先行者学习网
screenWidth : 500, cbnHTML5中文学习网 - HTML5先行者学习网
screenHeight : 400, cbnHTML5中文学习网 - HTML5先行者学习网
pond : null, cbnHTML5中文学习网 - HTML5先行者学习网
textureImg : null, cbnHTML5中文学习网 - HTML5先行者学习网
interval : null, cbnHTML5中文学习网 - HTML5先行者学习网
backgroundURL : 'data_images/underwater1.jpg', cbnHTML5中文学习网 - HTML5先行者学习网
// initialization cbnHTML5中文学习网 - HTML5先行者学习网
init : function() { cbnHTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById('water'); cbnHTML5中文学习网 - HTML5先行者学习网
if (canvas.getContext){ cbnHTML5中文学习网 - HTML5先行者学习网
// fps countrt cbnHTML5中文学习网 - HTML5先行者学习网
fps = 0; cbnHTML5中文学习网 - HTML5先行者学习网
setInterval(function() { cbnHTML5中文学习网 - HTML5先行者学习网
document.getElementById('fps').innerHTML = fps / 2 + ' FPS'; cbnHTML5中文学习网 - HTML5先行者学习网
fps = 0; cbnHTML5中文学习网 - HTML5先行者学习网
}, 2000); cbnHTML5中文学习网 - HTML5先行者学习网
canvas.onmousedown = function(e) { cbnHTML5中文学习网 - HTML5先行者学习网
var mouse = watereff.getMousePosition(e).sub(new vector2d(canvas.offsetLeft, canvas.offsetTop)); cbnHTML5中文学习网 - HTML5先行者学习网
watereff.pond.buffer1[mouse.y * watereff.pond.x + mouse.x ] += 200; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
canvas.onmouseup = function(e) { cbnHTML5中文学习网 - HTML5先行者学习网
canvas.onmousemove = null; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
canvas.width = this.screenWidth; cbnHTML5中文学习网 - HTML5先行者学习网
canvas.height = this.screenHeight; cbnHTML5中文学习网 - HTML5先行者学习网
this.textureImg = new Image(256, 256); cbnHTML5中文学习网 - HTML5先行者学习网
this.textureImg.src = this.backgroundURL; cbnHTML5中文学习网 - HTML5先行者学习网
canvas.getContext('2d').drawImage(this.textureImg, 0, 0); cbnHTML5中文学习网 - HTML5先行者学习网
this.pond = new drop( cbnHTML5中文学习网 - HTML5先行者学习网
this.screenWidth, cbnHTML5中文学习网 - HTML5先行者学习网
this.screenHeight, cbnHTML5中文学习网 - HTML5先行者学习网
this.damping, cbnHTML5中文学习网 - HTML5先行者学习网
this.shading, cbnHTML5中文学习网 - HTML5先行者学习网
this.refractions, cbnHTML5中文学习网 - HTML5先行者学习网
canvas.getContext('2d'), cbnHTML5中文学习网 - HTML5先行者学习网
this.screenWidth, this.screenHeight cbnHTML5中文学习网 - HTML5先行者学习网
); cbnHTML5中文学习网 - HTML5先行者学习网
if (this.interval != null){ cbnHTML5中文学习网 - HTML5先行者学习网
clearInterval(this.interval); cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
this.interval = setInterval(watereff.run, this.timeStep); cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
}, cbnHTML5中文学习网 - HTML5先行者学习网
// change image func cbnHTML5中文学习网 - HTML5先行者学习网
changePicture : function(url){ cbnHTML5中文学习网 - HTML5先行者学习网
this.backgroundURL = url; cbnHTML5中文学习网 - HTML5先行者学习网
this.init(); cbnHTML5中文学习网 - HTML5先行者学习网
}, cbnHTML5中文学习网 - HTML5先行者学习网
// get mouse position func cbnHTML5中文学习网 - HTML5先行者学习网
getMousePosition : function(e){ cbnHTML5中文学习网 - HTML5先行者学习网
if (!e){ cbnHTML5中文学习网 - HTML5先行者学习网
var e = window.event; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
if (e.pageX || e.pageY){ cbnHTML5中文学习网 - HTML5先行者学习网
return new vector2d(e.pageX, e.pageY); cbnHTML5中文学习网 - HTML5先行者学习网
} else if (e.clientX || e.clientY){ cbnHTML5中文学习网 - HTML5先行者学习网
return new vector2d(e.clientX, e.clientY); cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
}, cbnHTML5中文学习网 - HTML5先行者学习网
// loop drawing cbnHTML5中文学习网 - HTML5先行者学习网
run : function(){ cbnHTML5中文学习网 - HTML5先行者学习网
var ctx = document.getElementById('water').getContext('2d'); cbnHTML5中文学习网 - HTML5先行者学习网
watereff.pond.update(); cbnHTML5中文学习网 - HTML5先行者学习网
watereff.pond.draw(ctx); cbnHTML5中文学习网 - HTML5先行者学习网
fps++; cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
window.onload = function(){ cbnHTML5中文学习网 - HTML5先行者学习网
watereff.init(); cbnHTML5中文学习网 - HTML5先行者学习网
} cbnHTML5中文学习网 - HTML5先行者学习网
cbnHTML5中文学习网 - HTML5先行者学习网正如你所看到的,这里使用 Vector2D 函数,这个函数在 vector2d.js 里提供了。另一个很难的方法是使用纯数学实现,感兴趣的可以自己实验一下。
cbnHTML5中文学习网 - HTML5先行者学习网