分享一個插件-水珠自動下落效果


   分享一個水珠自動下落的插件,下載地址:https://github.com/foreverjiangting/rainyday.js 

  下面來看看如何使用它?添加下面代碼即可運行它。

  實現效果如下:

 

 代碼如下:

<!DOCTYPE HTML>
<html>
<head>
<style>
</style>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<script type="text/javascript">
     function  runImage()
     {
           var  image=document.getElementById("img");
           image.src="4.jpg";
           image.onload=function()
           {
                 //設定一個rain對象
                 var  engine=new RainyDay({image:this,});
//調用rain函數 engine.rain([[
4,6,8000]]);//設定雨滴大小4,6 數量為8000 ||也可為 engine.rain([[6,8000]]),此時水珠的大小較小 engine.rain([[3,3,0.88],[5,5,0.9],[6,2,1]],100);//設定雨滴重復時間 } // image.crossOrigin="jt"; 加載跨域圖片 } </script> </head> <body onload="runImage();" > <div class="rain"> <img src="4.jpg" id="img" alt="點擊圖片"> </div> <script type="text/javascript" src="rainy.js"></script> </body> </html>

 下面來研究下rainy.js部分代碼,源代碼見上面的github里面的:

RainyDay.prototype.rain = function(presets, speed) {
    // 准備canvas 進行下落映射
    if (this.reflection !== this.REFLECTION_NONE) {
        this.prepareReflections();
    }
    this.animateDrops();
    // 動畫
    this.presets = presets;
    this.PRIVATE_GRAVITY_FORCE_FACTOR_Y = (this.options.fps * 0.001) / 25;
    this.PRIVATE_GRAVITY_FORCE_FACTOR_X = ((Math.PI / 2) - this.options.gravityAngle) * (this.options.fps * 0.001) / 50;
    // 准備下落的模型
    if (this.options.enableCollisions) {

        // 計算最大的下落水珠圓角
        var maxDropRadius = 0;
        for (var i = 0; i < presets.length; i++) {
            if (presets[i][0] + presets[i][1] > maxDropRadius) {
                maxDropRadius = Math.floor(presets[i][0] + presets[i][1]);
            }
        }

        if (maxDropRadius > 0) {
            // 初始化下落的模型
            var mwi = Math.ceil(this.canvas.width / maxDropRadius);
            var mhi = Math.ceil(this.canvas.height / maxDropRadius);
            this.matrix = new CollisionMatrix(mwi, mhi, maxDropRadius);
        } else {
            this.options.enableCollisions = false;
        }
    }

    for (var i = 0; i < presets.length; i++) {
        if (!presets[i][3]) {
            presets[i][3] = -1;
        }
    }
    var lastExecutionTime = 0;
    this.addDropCallback = function() {
        var timestamp = new Date().getTime();
        if (timestamp - lastExecutionTime < speed) {
            return;
        }
        lastExecutionTime = timestamp;
        var context = this.canvas.getContext('2d');
        context.clearRect(0, 0, this.canvas.width, this.canvas.height);
        context.drawImage(this.background, 0, 0, this.canvas.width, this.canvas.height);
        // 選擇匹配的模型
        var preset;
        for (var i = 0; i < presets.length; i++) {
            if (presets[i][2] > 1 || presets[i][3] === -1) {
                if (presets[i][3] !== 0) {
                    presets[i][3]--;
                    for (var y = 0; y < presets[i][2]; ++y) {
                        this.putDrop(new Drop(this, Math.random() * this.canvas.width,
Math.random() * this.canvas.height, presets[i][0], presets[i][1])); } } } else if (Math.random() < presets[i][2]) { preset = presets[i]; break; } } if (preset) { this.putDrop(new Drop(this, Math.random() * this.canvas.width, Math.random() * this.canvas.height, preset[0], preset[1])); } context.save(); context.globalAlpha = this.opacity; context.drawImage(this.glass, 0, 0, this.canvas.width, this.canvas.height); context.restore(); } .bind(this); };

   這里我想提到關於跨域資源的問題,image.crossOrigin="jt"; 加載跨域圖片。剛開始我用的是跨域的圖片,但出現問題了,然后我就使用本地

的圖片加載, src="4.jpg" ,就沒問題了。其實如果你要使用跨域的圖片,只要加上image.crossOrigin="jt"; 這句代碼就可以了。

  (前提是服務器開了允許的權限)

   這里涉及到CORS的問題,我們來看下: CORS全稱是"跨域資源共享"(Cross-origin resource sharing)。它允許瀏覽器向跨源服務器

發出xmlhttprequest請求從而克服了AJAX只能同源使用的限制。

 我們還用上面的列子來看問題:

<!DOCTYPE HTML>
<html>
<head>
<style>
</style>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<script type="text/javascript">
     function  runImage()
     {
           var  image=document.getElementById("img");
           image.onload=function()
           {
                 //設定一個rain對象
                 var  engine=new RainyDay({image:this,});
           
                 engine.rain([[4,6,8000]]);//設定雨滴大小4,6 數量為8000
                 engine.rain([[3,3,0.88],[5,5,0.9],[6,2,1]],100);//設定雨滴重復時間
           }
          // image.crossOrigin="jt"; //跨域圖片
          image.src="http://img0.imgtn.bdimg.com/it/u=938096994,3074232342&fm=21&gp=0.jpg";        
     }
</script>
</head>
<body  onload="runImage();" >
<div class="rain">
   <img src="http://img0.imgtn.bdimg.com/it/u=938096994,3074232342&fm=21&gp=0.jpg"  id="img"  alt="點擊圖片">
</div>
 <script type="text/javascript"  src="rainy.js"></script>
 
</body>
</html>

 我們來看下調試控制台里面的信息:

Accept    
image/png,image/*;q=0.8,*/*;q=0.5
Accept-Encoding    
gzip, deflate
Accept-Language    
zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3
Connection    
keep-alive
Host    
img0.imgtn.bdimg.com
Origin  null ---上面的頭信息中,Origin字段用來說明,本次請求來自哪個源(協議 + 域名 + 端口)。服務器根據這個值
決定是否同意這次請求.不在許可范圍內。服務器會返回一個正常的HTTP回應。瀏覽器發現,
這個回應的頭信息沒有包含Access-Control-Allow-Origin字段(詳見下文),就知道出錯了,從而拋出一個錯誤,
XMLHttpRequestonerror回調函數捕獲。注意,這種錯誤無法通過狀態碼識別,因為HTTP回應的狀態碼有可能是200。
GET /cors HTTP/1.1
Origin: http://api.bob.com Host: api.alice.com Accept-Language: en-US Connection: keep-alive User-Agent: Mozilla/5.0.
User-Agent    
Mozilla/5.0 (Windows NT 6.1; rv:46.0) Gecko/20100101 Firefox/46.0

如果Origin指定的域名在許可范圍內,服務器返回的響應,會多出幾個頭信息字段。


作者:向婷風

出處:http://www.cnblogs.com/jtjds/p/5528497.html

如果您覺得閱讀本文對您有幫助,請點一下“推薦”按鈕,您的“推薦”將是我最大的寫作動力!歡迎各位轉載,但是未經作者

本人同意 轉載文章之后必須在 文章頁面明顯位置給出作者和原文連接,否則保留追究法律責任的權利。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM