首頁 >web前端 >js教程 >javascript實現很浪漫的氣泡冒出特效_javascript技巧

javascript實現很浪漫的氣泡冒出特效_javascript技巧

ringa_lee
ringa_lee原創
2018-05-14 16:12:411929瀏覽

本文實例講述了javascript實現很浪漫的氣泡冒出特效程式碼。分享給大家供大家參考。具體如下:
運作效果截圖如下:

具體程式碼如下:

實現想法>HTML裡只需要一個CANVAS元素,Javascript裡操作canvas1、給canvas裡繪製背景圖片2、在繪製半徑為0-10px的圓形,x座標螢幕水平隨機,y所標豎直大於螢幕高度。
  圓形背景色可以是隨機,那就是各種色彩了!
    利用計時器控制y--


建構html

<!doctype html> <html>  
<head>  
<meta charset="UTF-8">  
<meta name="Generator" content="EditPlus®">  
<meta name="Author" content="">  
<meta name="Keywords" content="">  
<meta name="Description" content="">  
<title>5多个小球往上运动</title>  
<style>  
</style>  
</head>  
<body>   
<p id="d1">     
<canvas id="canvas"></canvas>   
</p>  
</body> </html>



<script>   
var canvas=document.getElementById("canvas");   
var context=canvas.getContext("2d");   
canvas.width=window.innerWidth;   
canvas.height=window.innerHeight;   
function Circle()
{     
this.x=Math.random()*canvas.width;     
this.y=canvas.height;     
this.r=Math.random()*10;     
//绘制圆形     
this.paint=function()
{       
context.beginPath();       
context.arc(this.x,this.y,this.r,0,Math.PI*2);       
context.fillStyle="white";       
context.globalAlpha = 0.5;       
context.fill();     
}     
//控制圆形移动     
this.step=function()
{       
this.y--;     
}   
}   
var circles=[];   
function createCircles()
{     
var circle=new Circle();//??????     
circles[circles.length]=circle;   
}     
function paintCircles(){     
for(var i=0;i<circles.length;i++){       
circles[i].paint();     
}   
}   
function stepCircles()
{     
for(var i=0;i<circles.length;i++){       
circles[i].step();     
}   
}   
var myimg=new Image();   
myimg.src="images/demo-1.png";   
var timer="";   
setInterval(function(){     
context.drawImage(myimg,0,0);     
timer++;     
if(timer%20==0)
{       
createCircles();     
}     
paintCircles();     
stepCircles();   
},10);
 </script>
需要在自己的網站中加入浪漫元素,這不失為一種好的方式,希望大家靈活運用javascript實現氣泡冒出特效,謝謝大家的閱讀。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn