午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > 使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發(fā)

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

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

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

源碼下載

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ù),這個函數(shù)在 vector2d.js 里提供了。另一個很難的方法是使用純數(shù)學(xué)實現(xiàn),感興趣的可以自己實驗一下。

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發(fā)》,本文關(guān)鍵詞  使用,HTML5,Canvas,制作,水,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發(fā)》相關(guān)的同類信息!
  • 本頁收集關(guān)于使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發(fā)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    亚洲男人天堂网址| 一级特黄aaa大片| 91免费视频观看| 亚洲国产美女精品久久久久∴| 97超碰色婷婷| 久久精品一卡二卡| 日韩avvvv在线播放| 欧美一区二区视频观看视频| 午夜久久资源| 日韩中文字幕高清| 欧美性一级生活| 日韩国产在线一区| 激情综合网五月天| 欧美国产日韩在线观看| 欧美激情欧美激情| 9久久婷婷国产综合精品性色| 国产精品乱码一区二区| 色欲综合视频天天天| 91视频国产一区| 在线天堂www在线国语对白| 石原莉奈一区二区三区在线观看 | 亚洲国产古装精品网站| 婷婷久久五月天| 日韩av在线看免费观看| 久久久久久久久久久电影| 91av福利视频| 妺妺窝人体色www婷婷| 日本高清不卡一区| 国产人妻人伦精品| 日韩高清一级片| 欧美日韩一区高清| 少妇户外露出[11p]| 日韩精品成人免费观看视频| 日韩av综合网| 五月婷六月丁香| 亚洲少妇最新在线视频| 亚洲精品国产精品国自产观看 | 亚洲成人一区二区三区| 丰满人妻一区二区三区无码av| 中文字幕亚洲综合| 在线免费观看日韩av| 天天免费综合色| 天堂8在线天堂资源bt| 国产精品自在在线| 国产尤物99| 丰满熟女一区二区三区| 久久福利网址导航| 天堂av手机版| 无码aⅴ精品一区二区三区浪潮| 亚洲国产婷婷综合在线精品| 懂色av粉嫩av蜜臀av一区二区三区| 色国产综合视频| 国产精品成人免费电影| 亚洲麻豆一区二区三区| 精品久久久久久国产| 国产偷人视频免费| 亚洲精品国偷自产在线99热| 精品人妻一区二区免费视频| 欧美一区二区三区视频在线| 中文字幕一区三区久久女搜查官| 欧美性大战久久久| 中文字幕第17页| 91国偷自产一区二区三区观看| 成人免费在线小视频| 99国产欧美另类久久久精品| 69精品丰满人妻无码视频a片| 亚洲精品91在线| 欧美私模裸体表演在线观看| 在线免费观看av网| 精品国产乱码久久久久久久| xxxx黄色片| 午夜精品福利一区二区三区av| 日韩欧美一区二区三区四区| 国产毛片一区二区| 国产综合av一区二区三区| 国产一区二区美女诱惑| 欧美精品二区三区四区免费看视频 | 欧美性大战久久| 日本黄色网址大全| 亚洲欧美精品suv| 强乱中文字幕av一区乱码| 久久国产精品久久国产精品| 国产美女免费视频| 国产69精品久久久久9999apgf| 99久久99久久精品国产片果冻| 99在线精品免费视频| 亚洲成av人影院| 国产精品无码一区二区三区| 尤物yw午夜国产精品视频| 一级做a爰片久久毛片| 成人a视频在线观看| www.99精品| 午夜肉伦伦影院| 色哟哟日韩精品| 中文字幕 91| 在线精品视频一区二区三四 | 久久久免费精品视频| 91福利在线观看视频| 99re国产视频| 亚洲视频狠狠干| 中文幕无线码中文字蜜桃| 日韩一区二区三区免费看| 2019男人天堂| 国产精品久久久久国产a级| 成人激情综合网站| 欧美一级片黄色| 韩国欧美亚洲国产| 高清日韩电视剧大全免费| 亚洲最大成人在线观看| 在线一区二区日韩| 久久精品国产亚洲高清剧情介绍| 日本黄色三级大片| 久久精品国产69国产精品亚洲| 看电视剧不卡顿的网站| youjizzxxxx18| 国产一区二区美女视频| 久久天堂精品| 91精品999| 欧美猛男性生活免费| 高清成人免费视频| www.日本高清| 福利视频一区二区三区| 国产日韩精品视频一区| 免费一级特黄毛片| 欧美视频13p| 男人在线观看视频| 成人av网站观看| 色美美综合视频| 国产精品xxxxxx| 国产无限制自拍| 日本亚洲欧洲色α| 久久久午夜精品理论片中文字幕| 性の欲びの女javhd| 国产精品一区二区三区在线观| 日韩欧美亚洲综合| 久久最新视频| 免费不卡的av| 91久久精品国产91久久性色| 欧美性猛交xxxx黑人| 中文字幕在线观看1| 日韩av一二三四| 57pao国产成人免费| 午夜精品福利一区二区三区av| a级片在线观看免费| 中国黄色录像片| 久久亚洲精品小早川怜子66| 国产精品久久久久7777按摩| 最近中文字幕免费在线观看| 日韩中文字幕a| 日本精品性网站在线观看| 日本大香伊一区二区三区| 91丨porny丨在线中文 | 国产高清中文字幕| 东北少妇不带套对白| 2021国产精品视频| 欧美日韩国产精品一区| 麻豆视频一区二区| 欧美成人精品激情在线视频| 性生生活大片免费看视频| 91大神免费观看| 精品久久久久一区二区| 欧美亚洲日本在线| xxxxx99| 久草精品在线播放| 97超碰人人澡| 久久精品网站视频| 国产一伦一伦一伦| 奇米影视首页 狠狠色丁香婷婷久久综合 | 欧美日韩综合网| 日本在线视频www色| 欧美激情视频在线免费观看 欧美视频免费一 | 香蕉视频成人在线| 亚洲综合一区二区三区| 精品国产免费视频| 欧美精品日韩www.p站| 久热精品在线视频| 国产精品亚发布| 亚洲精品中文字幕在线| 综合久久五月天| 自拍偷拍亚洲欧美| 欧美特级限制片免费在线观看| 国产精品1区2区3区在线观看| 日韩一级在线视频| 中文字幕在线观看免费高清| 99视频在线免费| 一区二区不卡在线观看| 精品国产一二区| 国产一区二区三区免费观看| 国产亚洲精品久久久优势| 国产天堂在线播放| 国产夫妻在线观看| 亚洲人123区| 欧美午夜xxx| 亚洲福利在线视频| 欧美福利视频在线观看| 欧美综合77777色婷婷| 一区二区三区视频在线观看免费| 欧美一级特黄视频| 亚洲一区二区三区日韩| 初高中福利视频网站| 日韩av自拍偷拍| 能看毛片的网站| 东京热av一区| 四虎在线视频免费观看| 国产精品久久久久影院老司| 亚洲男人天堂av网| 永久555www成人免费| 亚洲综合在线做性| 69xxx免费| 91制片厂免费观看| 国产99久久久欧美黑人 | 精品国产一区二区三区久久久狼 | 欧美日韩二区三区| 91在线你懂得| 精品久久在线观看| 少妇人妻丰满做爰xxx| 欧美成年人视频在线观看| 国产亚洲制服色| 国产成人精品免费网站| 午夜av一区二区三区| 夜夜爽夜夜爽精品视频| 亚洲成人动漫一区| 午夜天堂影视香蕉久久| 婷婷成人激情在线网| 色偷偷成人一区二区三区91| 欧美性xxxx| av蓝导航精品导航| 欧美视频自拍偷拍| 国产精品久久久久久亚洲伦| 偷拍精品一区二区三区| 日韩精品视频播放| 制服丝袜第二页| 日本三级免费观看| 欧美 日韩 国产在线| 欧美专区在线视频| 亚洲人成欧美中文字幕| 色94色欧美sute亚洲13| 中文字幕乱码久久午夜不卡 | 精品国产91久久久久久| 91日韩在线专区| 久久一二三区| 亚洲一区二区视频在线播放| www.毛片com| 国产福利在线观看视频| 成人在线激情网| 色乱码一区二区三区熟女| 成人在线视频网站| 国内免费精品永久在线视频| 亚洲欧美中文日韩在线v日本| 欧美视频三区在线播放| 亚洲一区二区在线免费观看视频| 91一区一区三区| 国内精品久久久久影院一蜜桃| 精品人妻一区二区三区麻豆91| 中国一级免费毛片| 林心如三级全黄裸体| 亚洲精品无码一区二区| 国产第一页视频| av日韩在线看| 亚洲欧洲日本国产| 九色91视频| 99精品国产一区二区| 欧美专区在线观看| 久久久久成人精品| 深夜福利日韩在线看| 成人免费视频免费观看| 亚洲蜜臀av乱码久久精品蜜桃| 57pao国产成人免费| 日本不卡一区二区三区视频| 色婷婷一区二区三区在线观看| 精品在线视频免费| 久久国内精品自在自线400部| 尤物av一区二区| 中国china体内裑精亚洲片| 蜜桃av久久久亚洲精品| 久久久美女艺术照精彩视频福利播放| 免费久久99精品国产| 无码国产精品一区二区免费16| 国产精品免费无遮挡| 国产美女激情视频| 国产无套在线观看| 国产一级中文字幕| 欧美成人免费看| 免费在线观看一级片| 日韩三级在线观看视频| 国产美女网站视频| 免费一级黄色录像| 中文字幕求饶的少妇| 天堂网av2018| wwwav国产| 久久高清免费视频| 国产性生活网站| www.国产com| 成人免费毛片男人用品| 亚洲第一精品在线观看| 中文字幕一区在线播放| 久久久久久久久久一级| 中文文字幕一区二区三三| 一本色道久久综合精品婷婷| 在线免费观看日韩视频| a毛片在线免费观看| 懂色av成人一区二区三区| 午夜福利一区二区三区| 久久精品免费看| 国产不卡视频在线播放| 91网站在线观看视频| 国产日本一区二区| 亚洲精品国产一区二区精华液| 亚洲国产综合视频在线观看| 欧美特级www| 日韩视频一区二区三区在线播放 | 日韩成年人视频| 波多野结衣电影在线播放| 国产理论片在线观看| 国产黄色小视频在线观看| 91精品国产综合久久精品麻豆| 一区二区国产日产| 美女视频免费一区| 精品欧美一区二区在线观看| 欧美一级片免费观看| 中文字幕视频免费观看| 欧美视频国产精品| 亚洲综合大片69999| 久久久久亚洲AV成人| 亚洲第一成年网| 女性生殖扒开酷刑vk| 欧美三级理论片| 成年人在线观看av| 久草中文在线视频| 国产精品无码白浆高潮| 青草av.久久免费一区| 成人免费视频视频| 一个色综合av| 777久久久精品| 色噜噜亚洲精品中文字幕| 日韩免费观看av| 欧美精品免费观看二区| 91成人在线观看喷潮教学| 无码国产精品一区二区高潮| 亚洲精品国产精品乱码在线观看| 欧美一区二区三区网站| 美女日韩在线中文字幕| 久久众筹精品私拍模特| 天天综合网 天天综合色| 亚洲电影免费观看高清完整版在线观看 | 国产玉足脚交久久欧美| 国产在线视频三区| 国产亚洲第一页| 免费av网站观看| 26uuuu精品一区二区| 日本国产一区二区| 日韩中文字幕在线播放| 91久久精品www人人做人人爽| 免费网站永久免费观看| 中文字幕无码人妻少妇免费| 欧美bbbbbbbbbbbb精品| 日日夜夜免费精品视频| 中文字幕在线一区免费| 日韩精品一区国产麻豆| 91产国在线观看动作片喷水| 欧美日韩一区在线播放| 最新av免费在线观看| 精品在线免费观看视频| 五月婷婷在线播放| 国产精品久久久99| 亚洲国产精品高清久久久| 国产精彩精品视频| 黄色一级视频播放| 亚洲成人黄色av| 蜜桃视频污在线观看| 欧美激情中文不卡| 337p日本欧洲亚洲大胆精品| 国产精品美乳一区二区免费| 国产曰肥老太婆无遮挡| 日本猛少妇色xxxxx免费网站| 亚洲av无码一区二区三区dv| 久久久www成人免费无遮挡大片| 欧美美女喷水视频| 欧美一区二区三区四区在线| 91九色国产ts另类人妖| 国产aⅴ激情无码久久久无码| 国产三级第一页| 国产精品久久久久一区| 精品亚洲一区二区三区在线播放 | 人妻熟女aⅴ一区二区三区汇编| 国产又大又粗又硬| 国产精品午夜春色av| 日韩精品在线视频观看| 成人av男人的天堂| 亚洲精品在线网址| 中文字幕欧美色图| 欧美激情一区二区三区蜜桃视频 | 中日韩在线视频| www.涩涩爱| 久久草av在线| 欧美日韩国产a| 91精品国产综合久久男男| 国产精品igao| 黄色网址中文字幕| 日本一区二区三区高清不卡| 亚洲人成网在线播放| 茄子视频成人在线观看 | 欧美一区二区视频在线观看| 国产精选久久久久久| 国产九九在线观看| 国产精品自产拍| 黄色成人在线免费| 国产精品久久久久久久天堂| 日本中文字幕二区| jlzzjlzzjlzz亚洲人|