婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

熱門標簽:邢臺縣地圖標注app 申請400電話流程簡介 外呼系統電話怎么投訴 阜陽企業外呼系統 南通數據外呼系統推廣 外呼線穩定線路 pageadm實現地圖標注 地圖標注位置能賺錢嗎 呼和浩特外呼電銷系統排名

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

源碼下載

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

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

巨人網絡通訊聲明:本文標題《使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發》,本文關鍵詞  使用,HTML5,Canvas,制作,水,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發》相關的同類信息!
  • 本頁收集關于使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    caoporm超碰国产精品| 欧美三级视频在线播放| 欧美日韩你懂得| 亚洲美女在线一区| 成人美女视频在线观看18| 1024成人网| 91精品国产一区二区三区蜜臀 | 欧美综合在线视频| 奇米影视一区二区三区| 久久久噜噜噜久噜久久综合| 日本v片在线高清不卡在线观看| 久久精品水蜜桃av综合天堂| 色综合天天综合狠狠| 天天综合天天做天天综合| 久久久久久久久久美女| 欧美亚洲综合色| 韩国精品在线观看| 亚洲一区视频在线| 欧美一卡二卡在线| 成人一区在线看| 日本亚洲三级在线| 国产精品国产自产拍高清av| 欧美乱妇23p| 成人免费视频视频在线观看免费| 亚洲激情一二三区| 精品处破学生在线二十三| 99久精品国产| 国产精品亚洲а∨天堂免在线| 国产一区视频网站| 国产电影精品久久禁18| 国产99久久久精品| bt7086福利一区国产| 色噜噜夜夜夜综合网| 欧亚一区二区三区| 欧美一区二区视频在线观看2020| 欧美成人性福生活免费看| 欧美xingq一区二区| 国产女同互慰高潮91漫画| 国产精品视频yy9299一区| **欧美大码日韩| 亚洲高清久久久| 久国产精品韩国三级视频| 粉嫩一区二区三区在线看| 91农村精品一区二区在线| 欧美日韩精品高清| 国产亚洲一区二区三区在线观看| 中文字幕色av一区二区三区| 亚洲一区二区av在线| 久久福利资源站| 不卡视频在线看| 欧美老肥妇做.爰bbww| 久久在线观看免费| 日韩理论片网站| 午夜欧美在线一二页| 国产制服丝袜一区| 欧洲精品在线观看| 国产人久久人人人人爽| 亚洲综合精品自拍| 国产剧情一区二区三区| 欧美在线不卡视频| 国产午夜亚洲精品不卡| 香蕉加勒比综合久久| 成人爽a毛片一区二区免费| 91精品国产色综合久久不卡蜜臀 | 国产在线看一区| 91在线观看成人| 26uuu欧美| 亚洲国产sm捆绑调教视频| 国产99久久久国产精品 | 91精品国产综合久久蜜臀 | 欧美激情一二三区| 日韩黄色小视频| 91尤物视频在线观看| 国产亚洲美州欧州综合国| 日韩av中文字幕一区二区三区| 成人黄页毛片网站| 2023国产精华国产精品| 日韩成人dvd| 欧美日韩一级二级| 亚洲黄色av一区| 成人aaaa免费全部观看| 久久婷婷国产综合国色天香| 视频一区二区三区在线| 欧美视频精品在线观看| 亚洲视频在线一区二区| 国产激情精品久久久第一区二区 | 久久综合九色综合97婷婷女人| 亚洲va韩国va欧美va精品| 91在线看国产| 国产精品护士白丝一区av| 国产成人在线观看| 国产亚洲午夜高清国产拍精品 | 91亚洲精品乱码久久久久久蜜桃| 欧美刺激午夜性久久久久久久| 五月婷婷激情综合网| 欧美性受xxxx| 一区二区三区在线播放| 91在线观看免费视频| 最新国产成人在线观看| 成人免费看片app下载| 国产精品久久久久一区| 成人性生交大片免费看中文 | 国产欧美日韩在线观看| 国产精品一区二区视频| 欧美va亚洲va香蕉在线| 久久精品999| 久久久久久久久久久电影| 粉嫩蜜臀av国产精品网站| 1区2区3区国产精品| 91成人在线精品| 日日摸夜夜添夜夜添国产精品| 日韩亚洲国产中文字幕欧美| 国产伦精一区二区三区| 亚洲欧洲精品天堂一级| 欧美日韩一区高清| 久久er精品视频| 久久久久久久久久久久久久久99| 大白屁股一区二区视频| 亚洲精品欧美二区三区中文字幕| 欧美另类z0zxhd电影| 国产一区999| 亚洲精品国久久99热| 欧美一级片在线| 波多野结衣精品在线| 性欧美疯狂xxxxbbbb| 久久久99免费| 色哟哟国产精品| 久久99热狠狠色一区二区| 国产精品电影一区二区| 91精品中文字幕一区二区三区| 国产精品亚洲午夜一区二区三区 | 91精品国产91热久久久做人人| 久久99国内精品| 亚洲免费视频成人| 欧美一区二区视频在线观看| 成人精品高清在线| 日本在线不卡视频一二三区| ㊣最新国产の精品bt伙计久久| 日韩欧美亚洲一区二区| www.欧美日韩国产在线| 日本va欧美va瓶| 亚洲欧美日韩国产另类专区 | 大胆亚洲人体视频| 日韩电影免费在线| 亚洲视频每日更新| 久久影院电视剧免费观看| 欧美精品三级在线观看| 99热这里都是精品| 国产一区二区三区精品欧美日韩一区二区三区 | 国产午夜精品理论片a级大结局 | 欧美亚洲一区三区| 粉嫩一区二区三区性色av| 日韩不卡在线观看日韩不卡视频| 亚洲色图在线播放| 国产欧美一区二区精品性| 7777女厕盗摄久久久| 欧美天堂一区二区三区| 成人app网站| 成人激情校园春色| 国产大陆a不卡| 国产一二精品视频| 精品一区精品二区高清| 青青草精品视频| 日韩av网站免费在线| 亚洲午夜一区二区三区| 亚洲人成在线观看一区二区| 国产精品色婷婷久久58| 26uuu成人网一区二区三区| 欧美精品aⅴ在线视频| 在线一区二区三区四区| 99精品国产99久久久久久白柏 | 欧美三级蜜桃2在线观看| 97久久久精品综合88久久| 成人午夜视频在线| 高清视频一区二区| 成人免费三级在线| 成人app软件下载大全免费| 国产99精品在线观看| 国产69精品一区二区亚洲孕妇| 成人性生交大片| 91视频.com| 91国产精品成人| 欧美日韩国产综合久久| 欧美久久久久久久久| 欧美另类videos死尸| 日韩欧美国产综合在线一区二区三区| 91精品蜜臀在线一区尤物| 精品久久久久99| 中文字幕国产一区| 亚洲激情欧美激情| 亚洲一区二区欧美日韩 | 国产激情91久久精品导航| 国产在线精品一区二区三区不卡| 精品在线视频一区| 国产999精品久久久久久绿帽| 国产91清纯白嫩初高中在线观看| 成人福利电影精品一区二区在线观看| 色综合久久综合网97色综合| 欧美美女激情18p| 久久久久久久精|