中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發
來源:易賢網 閱讀:3195 次 日期:2014-11-20 10:42:32
溫馨提示:易賢網小編為您整理了“使用 HTML5 Canvas 制作水波紋效果點擊圖片就會觸發”,方便廣大網友查閱!

今天,我們繼續分享 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 里提供了。另一個很難的方法是使用純數學實現,感興趣的可以自己實驗一下。

更多信息請查看IT技術專欄

更多信息請查看網頁制作
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
国产精品天天看| 亚洲大片在线观看| 亚洲一区影院| 亚洲二区在线观看| 国产精品一二三| 欧美日韩一级黄| 欧美黑人国产人伦爽爽爽| 久久免费视频网站| 性8sex亚洲区入口| 亚洲欧美成人在线| 亚洲欧美成人网| 亚洲一区二区三区精品视频| 99国产精品99久久久久久| 亚洲理伦在线| 99国产成+人+综合+亚洲欧美| 亚洲人成小说网站色在线| 亚洲日韩欧美视频一区| 亚洲精品影院在线观看| 一区二区三区国产在线| 亚洲天堂成人在线视频| 午夜精品美女久久久久av福利| 亚洲欧美日韩精品一区二区| 欧美亚洲自偷自偷| 久久裸体艺术| 欧美精品v日韩精品v国产精品 | 国产精品久久久久久久久借妻 | 午夜精品视频一区| 欧美一区二区三区在线视频 | 怡红院av一区二区三区| 尤物网精品视频| 在线观看日韩专区| 亚洲精品一区在线观看| 一区二区三区欧美日韩| 亚洲欧美在线看| 久久久在线视频| 欧美日韩高清在线| 国产精品日韩在线观看| 国产午夜一区二区三区| 亚洲国产精品女人久久久| 在线一区二区三区四区五区| 香蕉成人伊视频在线观看| 久久精品夜夜夜夜久久| 欧美激情一级片一区二区| 国产精品久久久爽爽爽麻豆色哟哟| 国产精品一区二区三区观看| 在线观看国产日韩| 亚洲一区中文| 美女图片一区二区| 国产精品久久久久久久一区探花| 樱桃国产成人精品视频| 亚洲一区日韩在线| 蜜臀久久99精品久久久久久9| 在线国产欧美| 一本色道久久综合精品竹菊| 欧美在线观看网站| 欧美精品系列| 国产综合欧美| 亚洲图色在线| 欧美国产日韩精品| 国产真实精品久久二三区| 日韩一区二区免费高清| 久久av红桃一区二区小说| 欧美日韩在线播放| 亚洲福利电影| 久久婷婷麻豆| 国产亚洲aⅴaaaaaa毛片| 日韩一级在线观看| 蜜臀av在线播放一区二区三区 | 亚洲一区二区三区精品视频| 老司机凹凸av亚洲导航| 国产精品日韩一区二区| 一区二区免费在线播放| 欧美成人在线免费观看| 精品福利av| 久久精品30| 国产日韩亚洲欧美综合| 亚洲一区免费观看| 欧美色视频在线| 99re6热只有精品免费观看| 男人天堂欧美日韩| 永久免费精品影视网站| 久久精品夜色噜噜亚洲a∨| 国产精品乱子久久久久| 一本色道久久综合亚洲精品按摩 | 久久视频这里只有精品| 国产精品入口66mio| 亚洲一区二区三区视频播放| 欧美日韩国产高清| 一区二区成人精品 | 国产欧美丝祙| 午夜精品一区二区三区在线播放| 欧美日韩一级视频| 这里只有精品电影| 国产精品久久久久久影视| 亚洲网站在线播放| 国产精品一级在线| 欧美一区二区三区四区视频| 国产日韩欧美精品| 久久国产色av| 1000部精品久久久久久久久| 狂野欧美激情性xxxx欧美| 亚洲国产精品视频一区| 欧美美女福利视频| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲视频在线看| 国产精品久久久久久超碰| 亚洲欧美日产图| 国产伦精品一区二区三区免费迷| 欧美一级专区| 精品动漫一区二区| 欧美美女bb生活片| 中日韩午夜理伦电影免费| 国产精品视频九色porn| 久久久久国产一区二区三区四区| 精品动漫av| 欧美人成网站| 午夜影视日本亚洲欧洲精品| 激情综合五月天| 欧美另类在线播放| 亚洲综合激情| 亚洲成色www8888| 欧美日韩亚洲一区| 亚洲欧美国产另类| 亚洲高清视频的网址| 欧美日韩美女一区二区| 欧美一区二视频在线免费观看| 一区二区在线视频| 欧美亚州在线观看| 久久乐国产精品| 亚洲一区二区三区欧美| 伊人狠狠色j香婷婷综合| 欧美日韩国内自拍| 久久久一二三| 亚洲免费一区二区| 91久久综合| 国产婷婷成人久久av免费高清| 免费观看日韩av| 欧美一级理论片| 一本色道久久综合狠狠躁的推荐| 国产欧美一级| 欧美视频成人| 欧美福利在线| 久久亚洲二区| 香蕉精品999视频一区二区| 亚洲人体大胆视频| 悠悠资源网久久精品| 国产精品最新自拍| 欧美日韩三区| 免费观看在线综合| 久久国产精品久久久久久| 国产精品99久久久久久久久| 亚洲第一页在线| 国产曰批免费观看久久久| 国产精品久久久亚洲一区| 欧美日韩天天操| 欧美精品高清视频| 欧美 日韩 国产一区二区在线视频| 性欧美大战久久久久久久久| 亚洲一区成人| 国产精品99久久久久久久女警| 亚洲国产欧美一区二区三区同亚洲 | 欧美超级免费视 在线| 亚洲一区二区三区国产| 亚洲全黄一级网站| 亚洲高清在线观看| 伊人久久大香线| 欧美一级视频| 在线观看精品一区| 欧美日本亚洲| 久久成人亚洲| 亚洲网站视频| 日韩亚洲欧美成人一区| 国产精品一二三四| 欧美精品日本| 久久综合福利| 久久久另类综合| 久久精品国产免费| 中文av一区特黄| 一本色道久久综合亚洲二区三区 | 久久超碰97中文字幕| 欧美性生交xxxxx久久久| 久久久久久久欧美精品| 这里只有精品视频在线| 最新国产の精品合集bt伙计| 国产欧美日韩不卡免费| 欧美视频一区二区三区…| 欧美经典一区二区三区| 欧美视频二区| 国产精品手机在线| 亚洲国产综合在线| 中日韩美女免费视频网址在线观看 | 久久久精品日韩| 欧美在线视频播放| 亚洲激情国产精品| 国产精品久久国产愉拍 | 一区二区久久久久久| 一区二区久久久久久| 校园激情久久| 蜜臀av在线播放一区二区三区| 欧美黑人多人双交|