成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

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

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

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

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

源碼下載

Step 1. HTML

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

復制代碼
代碼如下:

<!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 代碼:

復制代碼
代碼如下:

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 代碼:

復制代碼
代碼如下:

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ù)學實現(xiàn),感興趣的可以自己實驗一下。

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

巨人網(wǎng)絡通訊聲明:本文標題《使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發(fā)》,本文關鍵詞  使用,HTML5,Canvas,制作,水,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關。
  • 相關文章
  • 下面列出與本文章《使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發(fā)》相關的同類信息!
  • 本頁收集關于使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發(fā)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    成人av在线天堂| 欧美成人免费在线视频| 亚洲天堂网站在线观看视频| 韩国三级日本三级少妇99| 午夜精品一区二区在线观看的| 国产精品视频免费在线| 在线观看亚洲大片短视频| 国产一级网站视频在线| 欧美极品少妇与黑人| 日本免费一区二区三区四区| 精品动漫av| 欧美日本视频在线| 欧美色图天堂网| 国产亚洲永久域名| 日本中文字幕影院| 成人丁香基地| 亚洲字幕在线观看| 岛国一区二区| va亚洲va日韩不卡在线观看| 国产调教打屁股xxxx网站| 成人一区二区在线| 国产精品中文| 亚洲高清在线精品| 一区三区视频| 亚洲自拍偷拍欧美| 亚洲乱码av中文一区二区| 91小视频免费观看| 天堂精品高清1区2区3区| 国产精品亚洲人成在99www| 国产91丝袜在线观看| 成人久久18免费网站漫画| 浴室偷拍美女洗澡456在线| 男女性杂交内射妇女bbwxz| 国产人妻互换一区二区| 99视频精品| 精国产品一区二区三区a片| 亚洲精品成人久久电影| 乱小说综合网站| 人人爽人人av| 精品久久人人做人人爱| 在线观看色视频| 日本高清不卡在线| 日韩福利视频导航| 欧美日韩电影在线观看| 91在线小视频| 欧美性猛交一区二区三区精品| 久久久久久久久久久久久久久99| 伊人一区二区三区久久精品| 免费电影日韩网站| 羞羞视频在线免费国产| 亚洲成人av一区二区| 日韩三级在线观看视频| 2019男人天堂| 国语自产精品视频在线看抢先版结局| 亚洲二区免费| 天堂在线亚洲| 国产成人综合欧美精品久久| 无码国产69精品久久久久同性| 欧美日韩免费电影| 好吊色视频一区二区三区| 妞干网在线播放| 日本无删减在线| 国产精品日韩在线一区| 欧美性xxxx极品高清hd直播| 欧美黄色激情视频| 在线观看一区| 神马午夜久久| 91中文字幕网| 精品69视频一区二区三区| 国产视频在线观看网站| 天天色天天爽| 黄网站app在线观看下载视频大全官网| 日韩在线播放中文字幕| 欧美日韩美女在线观看| 久久激情五月激情| 黄色污污视频在线观看| 性欧美亚洲xxxx乳在线观看| 亚洲二区三区四区| 美女一区二区三区视频| 国内伊人久久久久久网站视频| 粉嫩欧美一区二区三区高清影视| 三级国产在线观看| 污污的网站18| 欧美日韩不卡一区| 欧美12一14sex性hd| www.久久久久久久久久久| 六月丁香婷婷久久| 新狼窝色av性久久久久久| 毛片aaaaa| 波多视频一区| 米奇777在线欧美播放| 亚洲精品97久久中文字幕| 国产成人高清精品| 欧美精品 国产精品| 2017亚洲天堂1024| 日韩不卡一区二区三区| 国产99精品在线观看| 欧美美女bb生活片| 精品国产免费久久久久久婷婷| 国产福利视频一区二区三区| 天天综合网在线观看| 亚洲+小说+欧美+激情+另类| 99热在线免费观看| 午夜精品国产更新| 亚在线播放中文视频| 久久久免费在线观看| 欧美日韩在线视频首页| 麻豆资源在线| 亚洲欧美一区二区激情| 超碰在线一区| 久久国产精品二区| 国产一二精品视频| 91伦理视频在线观看| 中文字幕亚洲在线| 午夜精品久久久久久久99老熟妇| 欧美最猛性xxxxx亚洲精品| 在线欧美一区| 国产精品久久久久久久久久久免费看| 亚洲大胆人体大胆做受1| 少妇精品无码一区二区三区| 欧美精品制服第一页| 国产羞羞视频在线观看| 在线观看国产高清视频| 亚洲国产精品久久久久爰性色| 亚洲日本精品国产第一区| 国产iv一区二区三区| 一二三四社区欧美黄| 久久久国产精品一区| 国产精品久久久久久久9999| 亚洲精品久久久久久| 99久久精品国产色欲| 欧美亚洲精品一区| 激情四房婷婷| 在线观看国产福利| 欧美成人免费视频a| 久久精品国内一区二区三区水蜜桃| 成品网站w灬+源码1688网页| 亚洲精品一区av| 成年人视频在线观看免费| 久操手机在线视频| 久久99精品波多结衣一区| 日本高清xxxx| 日本免费在线视频观看| 99精品国产一区二区三区| 国产精品国精产品一二| 一本久道久久综合狠狠爱亚洲精品| 欧美成人综合在线| 欧美韩国日本| 国产欧美日韩视频| jazzjazz国产精品久久| 日本一区二区高清| 日本久久成人网| 亚洲国产av一区二区| 日韩大片在线永久免费观看网站| 国产精品ⅴa在线观看h| 国产精品视频免费| 正在播放国产对白害羞| 99久久精品费精品国产| 农民人伦一区二区三区| 亚洲精品一区| 中文字幕在线看视频国产欧美在线看完整| 99久久久久免费精品国产| 国产1区2区3区| 樱花草涩涩www在线播放| 日韩 欧美 精品| 极品美女扒开粉嫩小泬| 人妻精品无码一区二区| 97se狠狠狠综合亚洲狠狠| 成人毛片一区二区| 69亚洲精品久久久蜜桃小说| 国产成a人亚洲精品| 国产一区一区三区| 亚洲精品人妻无码| 一级片免费在线| 国产美女做爰免费视频软件| 国产视频手机在线观看| 成人高清伦理免费影院在线观看| 不卡的国产精品| 无码人妻久久一区二区三区不卡| 99久久夜色精品国产亚洲狼| 成人欧美一区二区三区黑人| 中文字幕一区二区人妻在线不卡| 久久99精品国产麻豆不卡| 亚洲永久av| 在线一区观看| 最新国产露脸在线观看| 老司机精品福利在线观看| 在线小视频你懂的| 国产成人三级在线观看| 日韩在线小视频| 在线观看黄色小视频| 日本黄色免费在线观看| 日韩伦人妻无码| 宅男午夜在线| www.精品在线| 91香蕉视频在线播放| 日本黄视频在线观看| 一级淫片免费看| fc2ppv完全颜出在线播放| 日韩欧美卡一卡二| 欧美二区乱c少妇| 大地资源第二页在线观看高清版| freehdxxxx| 欧美三区不卡| 色94色欧美一区| 一二三四国产精品| 麻豆视频入口| 久久精品免费看| 免费在线黄色片| 日本黄色一级视频| 精品剧情v国产在线观看| 欧美一级做a爰片免费视频| 99高清免费国产自产拍| 欧美日韩在线视频首页| 蜜桃在线一区二区三区精品| 国产精品视频免费| 国产精品18hdxxxⅹ在线| 97在线日本国产| 成年人午夜久久久| 亚洲午夜精品久久久久久人妖| 91美女高潮出水| 91麻豆国产福利在线观看| 亚州国产精品久久久| 激情文学一区| 欧美午夜无遮挡| 色综合久久久久综合99| av在线网址导航| 久热精品视频在线观看| 久久av一区二区三区漫画| 中文字幕视频免费观看| 亚洲少妇视频| y111111国产精品久久婷婷| 国产黄a三级三级| 国产情人综合久久777777| www.午夜色大片| 欧美老肥妇做.爰bbww| 视频一区二区三区四区五区| 日韩欧美在线不卡| 国产伦精一区二区三区| 国产美女在线精品| 国产精品论坛| 日本a在线免费观看| 日韩三区视频| 91视频99| 亚洲免费福利视频| 久久精品视频一区| 禁网站在线观看免费视频| 欧美一三区三区四区免费在线看| 婷婷综合激情| 国产欧美一区二区三区网站| 欧美午夜片在线免费观看| 四虎成人免费视频| 国产综合香蕉五月婷在线| 亚洲免费成人在线视频| 欧美久久久精品| 青娱乐国产盛宴| 波多野在线播放| 欧美色欧美亚洲另类七区| 麻豆国产在线播放| 国产欧美熟妇另类久久久| 国产精品一香蕉国产线看观看| av在线首页| 男人添女荫道口女人有什么感觉| 最近2019中文字幕大全第二页| 天天做天天爱天天综合网2021| hs网站在线观看| 国产 porn| 久久在线中文字幕| 欧洲精品在线一区| 日本一区二区三区在线不卡| 国产农村妇女精品一二区| 亚洲精品护士| 中文精品视频一区二区在线观看| 高清国语自产拍免费一区二区三区| 美女黄色片网站| 国产一区二区导航在线播放| 污污网站在线| 91手机视频在线观看| 国产精品伊人日日| 黄色网在线免费看| 日本蜜桃在线观看视频| 国产日韩成人内射视频| 亚洲视频在线免费看| 日本在线视频www色| 久久久久久国产免费a片| 亚洲美女色视频| 午夜探花在线观看| 欧美又黄又嫩大片a级| 久久中文免费视频| 免费一二一二在线视频| 亚洲伊人网在线观看| 色欧美自拍视频| 欧美日韩在线播| 久久久青草青青国产亚洲免观| 国产欧美激情视频| 亚洲人成在线影院| 欧美一级裸体视频| 国产精品-区区久久久狼| 韩国三级一区| 亚洲国产高清在线| 玖玖视频精品| 青青伊人久久| 神马久久一区二区三区| 青草青草久热精品视频在线网站| 国产精品劲爆视频| 午夜影院一区| 9191在线观看| 国产一区二区剧情av在线| 国产激情精品久久久第一区二区| 性色88av老女人视频| 国产中文字幕一区二区三区| 欧美电影一区二区| 亚洲精品中文字幕在线播放| 野花社区视频在线观看| 国产精品女视频| 国产精品九九九九九九| 亚洲一区二区在线免费| 亚洲自拍av在线| jvid福利在线一区二区| 五月天激情综合网| 91产国在线观看动作片喷水| 国产精品久久久久久久久久齐齐| 色吧影院999| 高清视频国产| 中文字幕佐山爱一区二区免费| 男女午夜激情视频| 色婷婷国产精品免| 少妇人妻在线视频|