2017-08-17 60 views
0

我想只有在用戶點擊一個按鈕後才能開始這個紙屑動畫。開始點擊紙屑

這裏是codepen鏈接合作:https://codepen.io/gamanox/pen/FkEbH?page=1&

var COLORS, Confetti, NUM_CONFETTI, PI_2, canvas, confetti, context, drawCircle, drawCircle2, drawCircle3, i, range, xpos; 

    NUM_CONFETTI = 60; 

    COLORS = [[255, 255, 255], [255, 144, 0], [255, 255, 255], [255, 144, 0], [0, 277, 235]]; 

    PI_2 = 2 * Math.PI; 

    canvas = document.getElementById("confeti"); 

    context = canvas.getContext("2d"); 

    window.w = 0; 

    window.h = 0; 

    window.resizeWindow = function() { 
    window.w = canvas.width = window.innerWidth; 
    return window.h = canvas.height = window.innerHeight; 
    }; 

    window.addEventListener('resize', resizeWindow, false); 

    window.onload = function() { 
    return setTimeout(resizeWindow, 0); 
    }; 

    range = function(a, b) { 
    return (b - a) * Math.random() + a; 
    }; 

    drawCircle = function(x, y, r, style) { 
    context.beginPath(); 
    context.moveTo(x, y); 
    context.bezierCurveTo(x - 17, y + 14, x + 13, y + 5, x - 5, y + 22); 
    context.lineWidth = 3; 
    context.strokeStyle = style; 
    return context.stroke(); 
    }; 

    drawCircle2 = function(x, y, r, style) { 
    context.beginPath(); 
    context.moveTo(x, y); 
    context.lineTo(x + 10, y + 10); 
    context.lineTo(x + 10, y); 
    context.closePath(); 
    context.fillStyle = style; 
    return context.fill(); 
    }; 

    drawCircle3 = function(x, y, r, style) { 
    context.beginPath(); 
    context.moveTo(x, y); 
    context.lineTo(x + 10, y + 10); 
    context.lineTo(x + 10, y); 
    context.closePath(); 
    context.fillStyle = style; 
    return context.fill(); 
    }; 

    xpos = 0.9; 

    document.onmousemove = function(e) { 
    return xpos = e.pageX/w; 
    }; 

    window.requestAnimationFrame = (function() { 
    return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function(callback) { 
     return window.setTimeout(callback, 100/20); 
    }; 
    })(); 

    Confetti = (function() { 
    function Confetti() { 
     this.style = COLORS[~~range(0, 5)]; 
     this.rgb = "rgba(" + this.style[0] + "," + this.style[1] + "," + this.style[2]; 
     this.r = ~~range(2, 6); 
     this.r2 = 2 * this.r; 
     this.replace(); 
    } 

    Confetti.prototype.replace = function() { 
     this.opacity = 0; 
     this.dop = 0.03 * range(1, 4); 
     this.x = range(-this.r2, w - this.r2); 
     this.y = range(-20, h - this.r2); 
     this.xmax = w - this.r; 
     this.ymax = h - this.r; 
     this.vx = range(0, 2) + 8 * xpos - 5; 
     return this.vy = 0.7 * this.r + range(-1, 1); 
    }; 

    Confetti.prototype.draw = function() { 
     var ref; 
     this.x += this.vx; 
     this.y += this.vy; 
     this.opacity += this.dop; 
     if (this.opacity > 1) { 
     this.opacity = 1; 
     this.dop *= -1; 
     } 
     if (this.opacity < 0 || this.y > this.ymax) { 
     this.replace(); 
     } 
     if (!((0 < (ref = this.x) && ref < this.xmax))) { 
     this.x = (this.x + this.xmax) % this.xmax; 
     } 
     drawCircle(~~this.x, ~~this.y, this.r, this.rgb + "," + this.opacity + ")"); 
     drawCircle3(~~this.x * 0.5, ~~this.y, this.r, this.rgb + "," + this.opacity + ")"); 
     return drawCircle2(~~this.x * 1.5, ~~this.y * 1.5, this.r, this.rgb + "," + this.opacity + ")"); 
    }; 

    return Confetti; 

    })(); 

    confetti = (function() { 
    var j, ref, results; 
    results = []; 
    for (i = j = 1, ref = NUM_CONFETTI; 1 <= ref ? j <= ref : j >= ref; i = 1 <= ref ? ++j : --j) { 
     results.push(new Confetti); 
    } 
    return results; 
    })(); 

    window.step = function() { 
    var c, j, len, results; 
    requestAnimationFrame(step); 
    context.clearRect(0, 0, w, h); 
    results = []; 
    for (j = 0, len = confetti.length; j < len; j++) { 
     c = confetti[j]; 
     results.push(c.draw()); 
    } 
    return results; 
    }; 

    step(); 

我試圖包裝下面的代碼到一個函數,然後與點擊jQuery的調用它,但它不工作。任何建議,將不勝感激

回答

1

添加點擊收聽該文件,並運行step()裏面:

//step() 
document.addEventListener "click",() => 
    step() 

https://codepen.io/jdoyle/pen/mMpQKR

這工作,但如果你點擊超過一次,你得到一些奇怪的結果。做一個小的重構,並刪除事件監聽器,一旦用戶點擊:

// step() 
start = -> 
    requestAnimationFrame(step) 
    document.removeEventListener "click", start 

document.addEventListener "click", start 
+0

謝謝!我只是自己注意到這個bug,然後回到這裏來發現你已經修好了:) –

0

替換:

confetti = (function() { 
    var j, ref, results; 
    results = []; 
    for (i = j = 1, ref = NUM_CONFETTI; 1 <= ref ? j <= ref : j >= ref; i = 1 <= ref ? ++j : --j) { 
     results.push(new Confetti); 
    } 
    return results; 
    })(); 

confetti = []; 

把點擊監聽器裏:

var j, ref; 
for (i = j = 1, ref = NUM_CONFETTI; 1 <= ref ? j <= ref : j >= ref; i = 1 <= ref ? ++j : --j) { 
    confetti.push(new Confetti); 
}