校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > 使用 HTML5 Canvas 制作水波紋效果點(diǎn)擊圖片就會(huì)觸發(fā)

使用 HTML5 Canvas 制作水波紋效果點(diǎn)擊圖片就會(huì)觸發(fā)

熱門標(biāo)簽:邢臺(tái)縣地圖標(biāo)注app 申請(qǐng)400電話流程簡(jiǎn)介 外呼系統(tǒng)電話怎么投訴 阜陽(yáng)企業(yè)外呼系統(tǒng) 南通數(shù)據(jù)外呼系統(tǒng)推廣 外呼線穩(wěn)定線路 pageadm實(shí)現(xiàn)地圖標(biāo)注 地圖標(biāo)注位置能賺錢嗎 呼和浩特外呼電銷系統(tǒng)排名

今天,我們繼續(xù)分享 JavaScript 實(shí)現(xiàn)的效果例子,這篇文章會(huì)介紹使用 JavaScript 實(shí)現(xiàn)水波紋效果。水波效果以圖片為背景,點(diǎn)擊圖片任意位置都會(huì)觸發(fā)。有時(shí)候,我們使用普通的 Javascript 就可以創(chuàng)建一個(gè)很有趣的解決功能。
 

源碼下載

Step 1. HTML

和以前一樣,首先是 HTML 代碼:

復(fù)制代碼
代碼如下:

<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8 />
<title>Water drops effect</title>
<link rel="stylesheet" href="css/main.css" type="text/css" />
<script src="js/vector2d.js" type="text/javascript" charset="utf-8"></script>
<script src="js/waterfall.js" type="text/javascript" charset="utf-8"></script>
</head>
<body>
<div class="example">
<h3><a href="#">Water drops effect</a></h3>
<canvas id="water">HTML5 compliant browser required</canvas>
<div id="switcher">
<img onclick='watereff.changePicture(this.src);' src="data_images/underwater1.jpg" />
<img onclick='watereff.changePicture(this.src);' src="data_images/underwater2.jpg" />
</div>
<div id="fps"></div>
</div>
</body>
</html> 

Step 2. CSS

這是用到的 CSS 代碼:

復(fù)制代碼
代碼如下:

body{background:#eee;margin:0;padding:0}
.example{background:#FFF;width:600px;border:1px #000 solid;margin:20px auto;padding:15px;-moz-border-radius: 3px;-webkit-border-radius: 3px}
#water {
width:500px;
height:400px;
display: block;
margin:0px auto;
cursor:pointer;
}
#switcher {
text-align:center;
overflow:hidden;
margin:15px;
}
#switcher img {
width:160px;
height:120px;
}

Step 3. JS

下面是主要的 JavaScript 代碼:

復(fù)制代碼
代碼如下:

function drop(x, y, damping, shading, refraction, ctx, screenWidth, screenHeight){
this.x = x;
this.y = y;
this.shading = shading;
this.refraction = refraction;
this.bufferSize = this.x * this.y;
this.damping = damping;
this.background = ctx.getImageData(0, 0, screenWidth, screenHeight).data;
this.imageData = ctx.getImageData(0, 0, screenWidth, screenHeight);
this.buffer1 = [];
this.buffer2 = [];
for (var i = 0; i < this.bufferSize; i++){
this.buffer1.push(0);
this.buffer2.push(0);
}
this.update = function(){
for (var i = this.x + 1, x = 1; i < this.bufferSize - this.x; i++, x++){
if ((x < this.x)){
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];
this.buffer2[i] *= this.damping;
} else x = 0;
}
var temp = this.buffer1;
this.buffer1 = this.buffer2;
this.buffer2 = temp;
}
this.draw = function(ctx){
var imageDataArray = this.imageData.data;
for (var i = this.x + 1, index = (this.x + 1) * 4; i < this.bufferSize - (1 + this.x); i++, index += 4){
var xOffset = ~~(this.buffer1[i - 1] - this.buffer1[i + 1]);
var yOffset = ~~(this.buffer1[i - this.x] - this.buffer1[i + this.x]);
var shade = xOffset * this.shading;
var texture = index + (xOffset * this.refraction + yOffset * this.refraction * this.x) * 4;
imageDataArray[index] = this.background[texture] + shade;
imageDataArray[index + 1] = this.background[texture + 1] + shade;
imageDataArray[index + 2] = 50 + this.background[texture + 2] + shade;
}
ctx.putImageData(this.imageData, 0, 0);
}
}
var fps = 0;
var watereff = {
// variables
timeStep : 20,
refractions : 2,
shading : 3,
damping : 0.99,
screenWidth : 500,
screenHeight : 400,
pond : null,
textureImg : null,
interval : null,
backgroundURL : 'data_images/underwater1.jpg',
// initialization
init : function() {
var canvas = document.getElementById('water');
if (canvas.getContext){
// fps countrt
fps = 0;
setInterval(function() {
document.getElementById('fps').innerHTML = fps / 2 + ' FPS';
fps = 0;
}, 2000);
canvas.onmousedown = function(e) {
var mouse = watereff.getMousePosition(e).sub(new vector2d(canvas.offsetLeft, canvas.offsetTop));
watereff.pond.buffer1[mouse.y * watereff.pond.x + mouse.x ] += 200;
}
canvas.onmouseup = function(e) {
canvas.onmousemove = null;
}
canvas.width = this.screenWidth;
canvas.height = this.screenHeight;
this.textureImg = new Image(256, 256);
this.textureImg.src = this.backgroundURL;
canvas.getContext('2d').drawImage(this.textureImg, 0, 0);
this.pond = new drop(
this.screenWidth,
this.screenHeight,
this.damping,
this.shading,
this.refractions,
canvas.getContext('2d'),
this.screenWidth, this.screenHeight
);
if (this.interval != null){
clearInterval(this.interval);
}
this.interval = setInterval(watereff.run, this.timeStep);
}
},
// change image func
changePicture : function(url){
this.backgroundURL = url;
this.init();
},
// get mouse position func
getMousePosition : function(e){
if (!e){
var e = window.event;
}
if (e.pageX || e.pageY){
return new vector2d(e.pageX, e.pageY);
} else if (e.clientX || e.clientY){
return new vector2d(e.clientX, e.clientY);
}
},
// loop drawing
run : function(){
var ctx = document.getElementById('water').getContext('2d');
watereff.pond.update();
watereff.pond.draw(ctx);
fps++;
}
}
window.onload = function(){
watereff.init();
}

正如你所看到的,這里使用 Vector2D 函數(shù),這個(gè)函數(shù)在 vector2d.js 里提供了。另一個(gè)很難的方法是使用純數(shù)學(xué)實(shí)現(xiàn),感興趣的可以自己實(shí)驗(yàn)一下。

標(biāo)簽:鶴崗 德州 辛集 黃山 撫順 楊凌 蚌埠 內(nèi)蒙古

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用 HTML5 Canvas 制作水波紋效果點(diǎn)擊圖片就會(huì)觸發(fā)》,本文關(guān)鍵詞  使用,HTML5,Canvas,制作,水,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用 HTML5 Canvas 制作水波紋效果點(diǎn)擊圖片就會(huì)觸發(fā)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于使用 HTML5 Canvas 制作水波紋效果點(diǎn)擊圖片就會(huì)觸發(fā)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    欧美色精品在线视频| 色噜噜狠狠成人中文综合 | 青青草97国产精品免费观看| 91免费看视频| 日本一区二区动态图| 无吗不卡中文字幕| 久久午夜电影网| 视频一区二区三区在线| 国产精品中文字幕日韩精品| 日韩欧美国产精品一区| 午夜精品aaa| 欧美一级精品在线| 亚洲第一精品在线| 一本色道综合亚洲| 亚洲综合一区二区三区| 91论坛在线播放| 亚洲精品写真福利| 在线观看欧美精品| 亚洲在线免费播放| 日韩午夜激情视频| 男男视频亚洲欧美| 欧美精品三级在线观看| 男女性色大片免费观看一区二区| 在线不卡免费欧美| 日本aⅴ免费视频一区二区三区| 欧美一区二区免费| 日韩av一区二区在线影视| 蜜臂av日日欢夜夜爽一区| 久久久精品免费网站| 久久99久久99精品免视看婷婷 | 欧美日本韩国一区| 亚洲欧美电影一区二区| 在线亚洲高清视频| 丝袜亚洲另类丝袜在线| 欧美韩国日本不卡| 91在线云播放| 亚洲男人的天堂在线aⅴ视频| 在线不卡免费欧美| 国产精品一区免费在线观看| 一级日本不卡的影视| 制服丝袜中文字幕亚洲| 紧缚捆绑精品一区二区| 一区二区三区电影在线播| 欧美日韩综合在线| 国产91在线看| 爽好久久久欧美精品| 久久综合色之久久综合| 欧美四级电影网| 国产一区高清在线| 中文字幕制服丝袜成人av| 欧美老女人在线| 国产精品一区二区在线看| 天天av天天翘天天综合网| 久久毛片高清国产| av亚洲产国偷v产偷v自拍| 久久精品国产亚洲5555| 中文字幕在线一区| 精品国产乱码久久| 男女激情视频一区| 久久综合狠狠综合久久激情| 在线观看av不卡| 国产成人精品午夜视频免费| 久久99热国产| 亚洲香肠在线观看| 91视频在线观看免费| 国产成人精品免费视频网站| 国产精品一二三四五| 一区二区三区免费观看| 久久久久久久性| 91精品久久久久久蜜臀| k8久久久一区二区三区| 精品一区二区免费在线观看| 亚洲国产精品视频| 国产精品伦一区二区三级视频| 日韩欧美区一区二| 欧美一二三四区在线| 欧美午夜免费电影| 国产一区二区三区香蕉| 日本中文字幕一区二区视频| 久久伊人蜜桃av一区二区| 欧美精品在线视频| 在线观看av一区| 91网上在线视频| 国产成人在线电影| 午夜精品久久久久久久99樱桃| 国产精品毛片高清在线完整版| 国产精品福利av| 国产午夜一区二区三区| 国产精品全国免费观看高清| 亚洲精品在线网站| 久久精品视频免费| 成人免费黄色大片| 国产馆精品极品| 国产在线看一区| 麻豆国产精品一区二区三区| 久久电影国产免费久久电影| 亚洲va天堂va国产va久| 日韩专区在线视频| 日韩精品一二三区| 亚洲一区二区3| 亚洲福利国产精品| 亚洲午夜精品在线| 蜜臀av亚洲一区中文字幕| 日韩经典中文字幕一区| 一区二区三区中文字幕| 亚洲激情一二三区| 亚洲影院理伦片| 麻豆91在线观看| 精品一区二区三区在线视频| 岛国一区二区在线观看| 99视频一区二区三区| 国产尤物一区二区| 91丨九色丨国产丨porny| 色综合久久久久久久久久久| 91精选在线观看| 精品日韩在线观看| 国产精品国产三级国产aⅴ入口 | 亚洲一区二区三区视频在线播放| 欧美激情一区二区三区| 欧美精品一区男女天堂| 亚洲国产精华液网站w| 成人欧美一区二区三区白人 | 亚洲一区二区三区在线看| 中文字幕日韩精品一区 | 丝袜美腿亚洲色图| 日韩av一区二区三区| 国产成人在线视频免费播放| 色婷婷精品大在线视频| 欧美综合在线视频| 精品伦理精品一区| 国产精品婷婷午夜在线观看| 日韩影院精彩在线| 国产一二三精品| 91免费国产在线| 制服丝袜av成人在线看| 久久免费看少妇高潮| 亚洲国产精品嫩草影院| 久久91精品久久久久久秒播| av一区二区三区在线| 日韩欧美国产一区在线观看| 久久影院午夜片一区| 亚洲国产日韩a在线播放| 久国产精品韩国三级视频| 欧美伊人精品成人久久综合97| 欧美一级生活片| 久久久91精品国产一区二区精品 | 国产一区二区三区黄视频| 91视视频在线观看入口直接观看www | 免费观看在线色综合| 国产sm精品调教视频网站| 欧美另类变人与禽xxxxx| 国产网红主播福利一区二区| 日韩精品色哟哟| 色哟哟国产精品| 欧美mv和日韩mv的网站| 蜜臀久久99精品久久久久久9| 国产日韩v精品一区二区| 久久精品国产亚洲aⅴ| 91久久国产综合久久| **网站欧美大片在线观看| 蜜桃av噜噜一区| 欧美福利视频导航| 亚洲日本护士毛茸茸| 久草这里只有精品视频| 日韩三级免费观看| 亚洲综合偷拍欧美一区色| 高清成人免费视频| 精品人伦一区二区色婷婷| 国产日韩成人精品| 亚洲一区在线观看网站| 成人18精品视频| 日韩免费高清av| 五月婷婷激情综合网| 欧美日韩精品久久久| 亚洲精品国产无天堂网2021| voyeur盗摄精品| 国产精品网站在线观看| 国产麻豆视频精品| 国产片一区二区| 国产在线精品一区二区夜色 | 亚洲欧美国产三级| 亚洲视频 欧洲视频| 成人一区二区视频| 亚洲精品一区二区三区影院| 麻豆精品在线观看| 337p亚洲精品色噜噜| 五月婷婷激情综合网| 日韩一区二区三区四区五区六区| 亚洲v精品v日韩v欧美v专区| 3atv一区二区三区| 免费在线看成人av| 亚洲精品一区在线观看| 国产激情一区二区三区| 欧美久久久久久蜜桃| 亚洲6080在线| 自拍偷拍欧美精品| 亚洲午夜一区二区| 成+人+亚洲+综合天堂| 国产精品成人免费精品自在线观看 | 在线成人av网站|