javascript實(shí)現(xiàn)起伏的水波背景效果

字號(hào):


    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)起伏的水波背景效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    本文實(shí)例為大家分享了js水波背景效果的實(shí)現(xiàn)代碼,供大家參考,具體內(nèi)容如下
    效果圖:
    名單
    實(shí)現(xiàn)代碼:
    代碼如下:
    <!DOCTYPE html>
    <html>
    <head>
     <title>水波背景</title>
     <meta charset="gb2312" />
     <style>
     html, body {width:100%; height:100%; padding:0; margin:0;}
     </style>
    </head>
    <body>
     <canvas id="canvas"></canvas>
     <script type="text/javascript">
      var canvas = document.getElementById('canvas'); 
      var ctx = canvas.getContext('2d'); 
      canvas.width = canvas.parentNode.offsetWidth; 
      canvas.height = canvas.parentNode.offsetHeight;
      //如果瀏覽器支持requestAnimFrame則使用requestAnimFrame否則使用setTimeout 
      window.requestAnimFrame = (function(){ 
      return window.requestAnimationFrame  || 
        window.webkitRequestAnimationFrame || 
        window.mozRequestAnimationFrame || 
        function( callback ){ 
         window.setTimeout(callback, 1000 / 60); 
        }; 
      })(); 
      // 波浪大小
      var boHeight = canvas.height / 10;
      var posHeight = canvas.height / 1.2;
      //初始角度為0 
      var step = 0; 
      //定義三條不同波浪的顏色 
      var lines = ["rgba(0,222,255, 0.2)", 
          "rgba(157,192,249, 0.2)", 
          "rgba(0,168,255, 0.2)"]; 
      function loop(){ 
       ctx.clearRect(0,0,canvas.width,canvas.height); 
       step++; 
       //畫3個(gè)不同顏色的矩形 
       for(var j = lines.length - 1; j >= 0; j--) { 
        ctx.fillStyle = lines[j]; 
        //每個(gè)矩形的角度都不同,每個(gè)之間相差45度 
        var angle = (step+j*50)*Math.PI/180; 
        var deltaHeight = Math.sin(angle) * boHeight;
        var deltaHeightRight = Math.cos(angle) * boHeight; 
        ctx.beginPath();
        ctx.moveTo(0, posHeight+deltaHeight); 
        ctx.bezierCurveTo(canvas.width/2, posHeight+deltaHeight-boHeight, canvas.width / 2, posHeight+deltaHeightRight-boHeight, canvas.width, posHeight+deltaHeightRight); 
        ctx.lineTo(canvas.width, canvas.height); 
        ctx.lineTo(0, canvas.height); 
        ctx.lineTo(0, posHeight+deltaHeight); 
        ctx.closePath(); 
        ctx.fill(); 
       }
       requestAnimFrame(loop);
      } 
      loop(); 
     </script>
    </body>
    </html>
    以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助。