Last active
July 23, 2018 17:53
-
-
Save Anish-Agnihotri/47e76d3e8699b315f739c0ebecb3746a to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(function() { | |
// Hungarian notation | |
// (http://en.wikipedia.org/wiki/Hungarian_notation) | |
// n - HTML-Node | |
// o - object | |
// s - string | |
// i - integer | |
// a - array | |
// b - boolean | |
// f - float | |
// p - Particle | |
// fn - function | |
// ctx - 2D Context | |
// General Functions | |
var app, fnAddEventListener, fnRequestAnimationFrame; | |
fnRequestAnimationFrame = function(fnCallback) { | |
var fnAnimFrame; | |
fnAnimFrame = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function(fnCallback) { | |
window.setTimeOut(fnCallback, 1000 / 60); | |
}; | |
fnAnimFrame(fnCallback); | |
}; | |
// Add Event Listener | |
fnAddEventListener = function(o, sEvent, fn) { | |
if (o.addEventListener) { | |
o.addEventListener(sEvent, fn, false); | |
} else { | |
o['on' + sEvent] = fn; | |
} | |
}; | |
app = function() { | |
var Particle, ctxRender, fAngle, fCosAngle, fMaxAX, fMaxAY, fMaxAZ, fPI, fSinAngle, fStartVX, fStartVY, fStartVZ, fVX, fnACos, fnCos, fnMax, fnMin, fnNextFrame, fnRender, fnRnd, fnRnd2, fnSetSize, fnSin, fnSwapList, gui, h, iProjSphereX, iProjSphereY, iRadiusSphere, nBody, oBuffer, oDoc, oRadGrad, oRender, oStats, w; | |
oStats = new Stats(); | |
oStats.setMode(0); | |
oStats.domElement.style.position = 'absolute'; | |
oStats.domElement.style.left = '0px'; | |
oStats.domElement.style.top = '0px'; | |
document.body.appendChild(oStats.domElement); | |
// General Elements | |
oDoc = document; | |
nBody = oDoc.body; | |
// Shortcuts | |
fPI = Math.PI; | |
fnMax = Math.max; | |
fnMin = Math.min; | |
fnRnd = Math.random; | |
fnRnd2 = function() { | |
return 2.0 * fnRnd() - 1.0; | |
}; | |
fnCos = Math.cos; | |
fnACos = Math.acos; | |
fnSin = Math.sin; | |
// Sphere Settings | |
iRadiusSphere = 150; | |
iProjSphereX = 0; | |
iProjSphereY = 0; | |
// Particle Settings | |
fMaxAX = 0.1; | |
fMaxAY = 0.1; | |
fMaxAZ = 0.1; | |
fStartVX = 0.001; | |
fStartVY = 0.001; | |
fStartVZ = 0.001; | |
fAngle = 0.0; | |
fSinAngle = 0.0; | |
fCosAngle = 0.0; | |
window.iFramesToRotate = 2100.0; | |
window.iPerspective = 220; | |
window.iNewParticlePerFrame = 4; | |
window.fGrowDuration = 120.0; | |
window.fWaitDuration = 340.0; | |
window.fShrinkDuration = 430.0; | |
window.aColor = [0, 126, 255]; | |
window.bgColor = [255, 255, 255]; | |
fVX = (2.0 * fPI) / window.iFramesToRotate; | |
oRadGrad = null; | |
ctxRender = nCanvasRender.getContext('2d'); | |
oRender = { | |
pFirst: null | |
}; | |
oBuffer = { | |
pFirst: null | |
}; | |
w = h = 0; | |
// gets/sets size | |
fnSetSize = function() { | |
nCanvasRender.width = w = window.innerWidth; | |
nCanvasRender.height = h = window.innerHeight; | |
iProjSphereX = w / 2; | |
iProjSphereY = h / 2; | |
return { | |
w: w, | |
h: h | |
}; | |
}; | |
fnSetSize(); | |
// window.onresize | |
fnAddEventListener(window, 'resize', fnSetSize); | |
fnSwapList = function(p, oSrc, oDst) { | |
if (p != null) { | |
// remove p from oSrc | |
if (oSrc.pFirst === p) { | |
oSrc.pFirst = p.pNext; | |
if (p.pNext != null) { | |
p.pNext.pPrev = null; | |
} | |
} else { | |
p.pPrev.pNext = p.pNext; | |
if (p.pNext != null) { | |
p.pNext.pPrev = p.pPrev; | |
} | |
} | |
} else { | |
// create new p | |
p = new Particle(); | |
} | |
p.pNext = oDst.pFirst; | |
if (oDst.pFirst != null) { | |
oDst.pFirst.pPrev = p; | |
} | |
oDst.pFirst = p; | |
p.pPrev = null; | |
return p; | |
}; | |
Particle = (function() { | |
// Particle | |
class Particle { | |
fnInit() { | |
this.fAngle = fnRnd() * fPI * 2; | |
this.fForce = fnACos(fnRnd2()); | |
this.fAlpha = 0; | |
this.bIsDead = false; | |
this.iFramesAlive = 0; | |
this.fX = iRadiusSphere * fnSin(this.fForce) * fnCos(this.fAngle); | |
this.fY = iRadiusSphere * fnSin(this.fForce) * fnSin(this.fAngle); | |
this.fZ = iRadiusSphere * fnCos(this.fForce); | |
this.fVX = fStartVX * this.fX; | |
this.fVY = fStartVY * this.fY; | |
this.fVZ = fStartVZ * this.fZ; | |
this.fGrowDuration = window.fGrowDuration + fnRnd2() * (window.fGrowDuration / 4.0); | |
this.fWaitDuration = window.fWaitDuration + fnRnd2() * (window.fWaitDuration / 4.0); | |
this.fShrinkDuration = window.fShrinkDuration + fnRnd2() * (window.fShrinkDuration / 4.0); | |
this.fAX = 0.0; | |
this.fAY = 0.0; | |
this.fAZ = 0.0; | |
} | |
fnUpdate() { | |
if (this.iFramesAlive > this.fGrowDuration + this.fWaitDuration) { | |
this.fVX += this.fAX + fMaxAX * fnRnd2(); | |
this.fVY += this.fAY + fMaxAY * fnRnd2(); | |
this.fVZ += this.fAZ + fMaxAZ * fnRnd2(); | |
this.fX += this.fVX; | |
this.fY += this.fVY; | |
this.fZ += this.fVZ; | |
} | |
this.fRotX = fCosAngle * this.fX + fSinAngle * this.fZ; | |
this.fRotZ = -fSinAngle * this.fX + fCosAngle * this.fZ; | |
this.fRadiusCurrent = Math.max(0.01, window.iPerspective / (window.iPerspective - this.fRotZ)); | |
this.fProjX = this.fRotX * this.fRadiusCurrent + iProjSphereX; | |
this.fProjY = this.fY * this.fRadiusCurrent + iProjSphereY; | |
this.iFramesAlive += 1; | |
if (this.iFramesAlive < this.fGrowDuration) { | |
this.fAlpha = this.iFramesAlive * 1.0 / this.fGrowDuration; | |
} else if (this.iFramesAlive < this.fGrowDuration + this.fWaitDuration) { | |
this.fAlpha = 1.0; | |
} else if (this.iFramesAlive < this.fGrowDuration + this.fWaitDuration + this.fShrinkDuration) { | |
this.fAlpha = (this.fGrowDuration + this.fWaitDuration + this.fShrinkDuration - this.iFramesAlive) * 1.0 / this.fShrinkDuration; | |
} else { | |
this.bIsDead = true; | |
} | |
if (this.bIsDead === true) { | |
fnSwapList(this, oRender, oBuffer); | |
} | |
this.fAlpha *= fnMin(1.0, fnMax(0.5, this.fRotZ / iRadiusSphere)); | |
this.fAlpha = fnMin(1.0, fnMax(0.0, this.fAlpha)); | |
} | |
}; | |
// Current Position | |
Particle.prototype.fX = 0.0; | |
Particle.prototype.fY = 0.0; | |
Particle.prototype.fZ = 0.0; | |
// Current Velocity | |
Particle.prototype.fVX = 0.0; | |
Particle.prototype.fVY = 0.0; | |
Particle.prototype.fVZ = 0.0; | |
// Current Acceleration | |
Particle.prototype.fAX = 0.0; | |
Particle.prototype.fAY = 0.0; | |
Particle.prototype.fAZ = 0.0; | |
// Projection Position | |
Particle.prototype.fProjX = 0.0; | |
Particle.prototype.fProjY = 0.0; | |
// Rotation | |
Particle.prototype.fRotX = 0.0; | |
Particle.prototype.fRotZ = 0.0; | |
// double linked list | |
Particle.prototype.pPrev = null; | |
Particle.prototype.pNext = null; | |
Particle.prototype.fAngle = 0.0; | |
Particle.prototype.fForce = 0.0; | |
Particle.prototype.fGrowDuration = 0.0; | |
Particle.prototype.fWaitDuration = 0.0; | |
Particle.prototype.fShrinkDuration = 0.0; | |
Particle.prototype.fRadiusCurrent = 0.0; | |
Particle.prototype.iFramesAlive = 0; | |
Particle.prototype.bIsDead = false; | |
return Particle; | |
}).call(this); | |
fnRender = function() { | |
var iCount, p; | |
ctxRender.fillStyle = "rgb(" + window.bgColor.join(',') + ")"; | |
ctxRender.fillRect(0, 0, w, h); | |
p = oRender.pFirst; | |
iCount = 0; | |
while (p != null) { | |
ctxRender.fillStyle = "rgba(" + window.aColor.join(',') + ',' + p.fAlpha.toFixed(4) + ")"; | |
ctxRender.beginPath(); | |
ctxRender.arc(p.fProjX, p.fProjY, p.fRadiusCurrent, 0, 2 * fPI, false); | |
ctxRender.closePath(); | |
ctxRender.fill(); | |
p = p.pNext; | |
iCount += 1; | |
} | |
}; | |
fnNextFrame = function() { | |
var iAddParticle, iCount, p, pNext; | |
oStats.begin(); | |
fAngle = (fAngle + fVX) % (2.0 * fPI); | |
fSinAngle = fnSin(fAngle); | |
fCosAngle = fnCos(fAngle); | |
iAddParticle = 0; | |
iCount = 0; | |
while (iAddParticle++ < window.iNewParticlePerFrame) { | |
p = fnSwapList(oBuffer.pFirst, oBuffer, oRender); | |
p.fnInit(); | |
} | |
p = oRender.pFirst; | |
while (p != null) { | |
pNext = p.pNext; | |
p.fnUpdate(); | |
p = pNext; | |
iCount++; | |
} | |
fnRender(); | |
oStats.end(); | |
return fnRequestAnimationFrame(function() { | |
return fnNextFrame(); | |
}); | |
}; | |
fnNextFrame(); | |
gui = new dat.GUI(); | |
gui.add(window, 'fGrowDuration').min(10).max(500).step(1); | |
gui.add(window, 'fWaitDuration').min(10).max(500).step(1); | |
gui.add(window, 'fShrinkDuration').min(10).max(500).step(1); | |
gui.add(window, 'iPerspective').min(150).max(1000).step(1); | |
gui.add(window, 'iNewParticlePerFrame').min(1).max(20).step(1); | |
gui.add(window, 'iFramesToRotate').min(50).max(2500).step(50).onChange(function() { | |
return fVX = (2.0 * fPI) / window.iFramesToRotate; | |
}); | |
gui.addColor(window, 'aColor').onChange(function() { | |
window.aColor[0] = ~~window.aColor[0]; | |
window.aColor[1] = ~~window.aColor[1]; | |
return window.aColor[2] = ~~window.aColor[2]; | |
}); | |
gui.addColor(window, 'bgColor').onChange(function() { | |
window.bgColor[0] = ~~window.bgColor[0]; | |
window.bgColor[1] = ~~window.bgColor[1]; | |
return window.bgColor[2] = ~~window.bgColor[2]; | |
}); | |
if (window.innerWidth < 1000) { | |
gui.close(); | |
window.iNewParticlePerFrame = 5; | |
} | |
window.app = this; | |
}; | |
fnAddEventListener(window, 'load', app); | |
}).call(this); | |
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":["<anonymous>"],"names":[],"mappings":"AAAA;EAAA;;;;;;;;;;;;;;AAAA,MAAA,GAAA,EAAA,kBAAA,EAAA;;EAcA,uBAAA,GAA0B,QAAA,CAAC,UAAD,CAAA;AACxB,QAAA;IAAA,WAAA,GACE,MAAM,CAAC,qBAAP,IACA,MAAM,CAAC,2BADP,IAEA,MAAM,CAAC,wBAFP,IAGA,MAAM,CAAC,sBAHP,IAIA,MAAM,CAAC,uBAJP,IAKA,QAAA,CAAC,UAAD,CAAA;MACE,MAAM,CAAC,UAAP,CAAkB,UAAlB,EAA8B,IAAA,GAAO,EAArC;IADF;IAGF,WAAA,CAAY,UAAZ;EAVwB,EAd1B;;;EA4BA,kBAAA,GAAqB,QAAA,CAAC,CAAD,EAAI,MAAJ,EAAY,EAAZ,CAAA;IACnB,IAAG,CAAC,CAAC,gBAAL;MACE,CAAC,CAAC,gBAAF,CAAmB,MAAnB,EAA2B,EAA3B,EAA+B,KAA/B,EADF;KAAA,MAAA;MAGE,CAAE,CAAA,IAAA,GAAO,MAAP,CAAF,GAAmB,GAHrB;;EADmB;;EAOrB,GAAA,GAAM,QAAA,CAAA,CAAA;AAEJ,QAAA,QAAA,EAAA,SAAA,EAAA,MAAA,EAAA,SAAA,EAAA,MAAA,EAAA,MAAA,EAAA,MAAA,EAAA,GAAA,EAAA,SAAA,EAAA,QAAA,EAAA,QAAA,EAAA,QAAA,EAAA,GAAA,EAAA,MAAA,EAAA,KAAA,EAAA,KAAA,EAAA,KAAA,EAAA,WAAA,EAAA,QAAA,EAAA,KAAA,EAAA,MAAA,EAAA,SAAA,EAAA,KAAA,EAAA,UAAA,EAAA,GAAA,EAAA,CAAA,EAAA,YAAA,EAAA,YAAA,EAAA,aAAA,EAAA,KAAA,EAAA,OAAA,EAAA,IAAA,EAAA,QAAA,EAAA,OAAA,EAAA,MAAA,EAAA;IAAA,MAAA,GAAS,IAAI,KAAJ,CAAA;IACT,MAAM,CAAC,OAAP,CAAe,CAAf;IACA,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,QAAxB,GAAmC;IACnC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,IAAxB,GAA+B;IAC/B,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,GAAxB,GAA8B;IAC9B,QAAQ,CAAC,IAAI,CAAC,WAAd,CAA0B,MAAM,CAAC,UAAjC,EALA;;IAQA,IAAA,GAAO;IACP,KAAA,GAAQ,IAAI,CAAC,KATb;;IAWA,GAAA,GAAM,IAAI,CAAC;IACX,KAAA,GAAQ,IAAI,CAAC;IACb,KAAA,GAAQ,IAAI,CAAC;IACb,KAAA,GAAQ,IAAI,CAAC;IACb,MAAA,GAAS,QAAA,CAAA,CAAA;aAAM,GAAA,GAAM,KAAA,CAAA,CAAN,GAAgB;IAAtB;IACT,KAAA,GAAQ,IAAI,CAAC;IACb,MAAA,GAAS,IAAI,CAAC;IACd,KAAA,GAAQ,IAAI,CAAC,IAlBb;;IAoBA,aAAA,GAAgB;IAChB,YAAA,GAAe;IACf,YAAA,GAAe,EAtBf;;IAwBA,MAAA,GAAS;IACT,MAAA,GAAS;IACT,MAAA,GAAS;IACT,QAAA,GAAW;IACX,QAAA,GAAW;IACX,QAAA,GAAW;IACX,MAAA,GAAS;IACT,SAAA,GAAY;IACZ,SAAA,GAAY;IAEZ,MAAM,CAAC,eAAP,GAAyB;IACzB,MAAM,CAAC,YAAP,GAAsB;IACtB,MAAM,CAAC,oBAAP,GAA8B;IAC9B,MAAM,CAAC,aAAP,GAAuB;IACvB,MAAM,CAAC,aAAP,GAAuB;IACvB,MAAM,CAAC,eAAP,GAAyB;IACzB,MAAM,CAAC,MAAP,GAAgB,CAAC,CAAD,EAAI,GAAJ,EAAS,GAAT;IAChB,MAAM,CAAC,OAAP,GAAiB,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX;IAEjB,GAAA,GAAM,CAAC,GAAA,GAAM,GAAP,CAAA,GAAc,MAAM,CAAC;IAE3B,QAAA,GAAW;IACX,SAAA,GAAY,aAAa,CAAC,UAAd,CAAyB,IAAzB;IAGZ,OAAA,GAAU;MAAC,MAAA,EAAQ;IAAT;IACV,OAAA,GAAU;MAAC,MAAA,EAAQ;IAAT;IAEV,CAAA,GAAI,CAAA,GAAI,EApDR;;IAuDA,SAAA,GAAY,QAAA,CAAA,CAAA;MACV,aAAa,CAAC,KAAd,GAAsB,CAAA,GAAI,MAAM,CAAC;MACjC,aAAa,CAAC,MAAd,GAAuB,CAAA,GAAI,MAAM,CAAC;MAClC,YAAA,GAAe,CAAA,GAAI;MACnB,YAAA,GAAe,CAAA,GAAI;aACnB;QAAC,CAAA,EAAG,CAAJ;QAAO,CAAA,EAAG;MAAV;IALU;IAOZ,SAAA,CAAA,EA9DA;;;IAiEA,kBAAA,CAAmB,MAAnB,EAA2B,QAA3B,EAAqC,SAArC;IAEA,UAAA,GAAa,QAAA,CAAC,CAAD,EAAI,IAAJ,EAAU,IAAV,CAAA;MACX,IAAG,SAAH;;QAEE,IAAG,IAAI,CAAC,MAAL,KAAe,CAAlB;UACE,IAAI,CAAC,MAAL,GAAc,CAAC,CAAC;UAChB,IAAwB,eAAxB;YAAA,CAAC,CAAC,KAAK,CAAC,KAAR,GAAgB,KAAhB;WAFF;SAAA,MAAA;UAIE,CAAC,CAAC,KAAK,CAAC,KAAR,GAAgB,CAAC,CAAC;UAClB,IAA2B,eAA3B;YAAA,CAAC,CAAC,KAAK,CAAC,KAAR,GAAgB,CAAC,CAAC,MAAlB;WALF;SAFF;OAAA,MAAA;;QAUE,CAAA,GAAI,IAAI,QAAJ,CAAA,EAVN;;MAYA,CAAC,CAAC,KAAF,GAAU,IAAI,CAAC;MACf,IAAyB,mBAAzB;QAAA,IAAI,CAAC,MAAM,CAAC,KAAZ,GAAoB,EAApB;;MACA,IAAI,CAAC,MAAL,GAAc;MACd,CAAC,CAAC,KAAF,GAAU;aACV;IAjBW;IAoBP;;;MAAN,MAAA,SAAA;QAmCE,MAAQ,CAAA,CAAA;UACN,IAAC,CAAA,MAAD,GAAU,KAAA,CAAA,CAAA,GAAU,GAAV,GAAgB;UAC1B,IAAC,CAAA,MAAD,GAAU,MAAA,CAAO,MAAA,CAAA,CAAP;UACV,IAAC,CAAA,MAAD,GAAU;UACV,IAAC,CAAA,OAAD,GAAW;UACX,IAAC,CAAA,YAAD,GAAgB;UAChB,IAAC,CAAA,EAAD,GAAM,aAAA,GAAgB,KAAA,CAAM,IAAC,CAAA,MAAP,CAAhB,GAAiC,KAAA,CAAM,IAAC,CAAA,MAAP;UACvC,IAAC,CAAA,EAAD,GAAM,aAAA,GAAgB,KAAA,CAAM,IAAC,CAAA,MAAP,CAAhB,GAAiC,KAAA,CAAM,IAAC,CAAA,MAAP;UACvC,IAAC,CAAA,EAAD,GAAM,aAAA,GAAgB,KAAA,CAAM,IAAC,CAAA,MAAP;UACtB,IAAC,CAAA,GAAD,GAAO,QAAA,GAAW,IAAC,CAAA;UACnB,IAAC,CAAA,GAAD,GAAO,QAAA,GAAW,IAAC,CAAA;UACnB,IAAC,CAAA,GAAD,GAAO,QAAA,GAAW,IAAC,CAAA;UACnB,IAAC,CAAA,aAAD,GAAiB,MAAM,CAAC,aAAP,GAAuB,MAAA,CAAA,CAAA,GAAW,CAAC,MAAM,CAAC,aAAP,GAAuB,GAAxB;UACnD,IAAC,CAAA,aAAD,GAAiB,MAAM,CAAC,aAAP,GAAuB,MAAA,CAAA,CAAA,GAAW,CAAC,MAAM,CAAC,aAAP,GAAuB,GAAxB;UACnD,IAAC,CAAA,eAAD,GAAmB,MAAM,CAAC,eAAP,GAAyB,MAAA,CAAA,CAAA,GAAW,CAAC,MAAM,CAAC,eAAP,GAAyB,GAA1B;UACvD,IAAC,CAAA,GAAD,GAAO;UACP,IAAC,CAAA,GAAD,GAAO;UACP,IAAC,CAAA,GAAD,GAAO;QAjBD;;QAoBR,QAAU,CAAA,CAAA;UACR,IAAG,IAAC,CAAA,YAAD,GAAgB,IAAC,CAAA,aAAD,GAAiB,IAAC,CAAA,aAArC;YACE,IAAC,CAAA,GAAD,IAAQ,IAAC,CAAA,GAAD,GAAO,MAAA,GAAS,MAAA,CAAA;YACxB,IAAC,CAAA,GAAD,IAAQ,IAAC,CAAA,GAAD,GAAO,MAAA,GAAS,MAAA,CAAA;YACxB,IAAC,CAAA,GAAD,IAAQ,IAAC,CAAA,GAAD,GAAO,MAAA,GAAS,MAAA,CAAA;YACxB,IAAC,CAAA,EAAD,IAAO,IAAC,CAAA;YACR,IAAC,CAAA,EAAD,IAAO,IAAC,CAAA;YACR,IAAC,CAAA,EAAD,IAAO,IAAC,CAAA,IANV;;UAQA,IAAC,CAAA,KAAD,GAAS,SAAA,GAAY,IAAC,CAAA,EAAb,GAAkB,SAAA,GAAY,IAAC,CAAA;UACxC,IAAC,CAAA,KAAD,GAAS,CAAC,SAAD,GAAa,IAAC,CAAA,EAAd,GAAmB,SAAA,GAAY,IAAC,CAAA;UACzC,IAAC,CAAA,cAAD,GAAkB,IAAI,CAAC,GAAL,CAAS,IAAT,EAAe,MAAM,CAAC,YAAP,GAAsB,CAAC,MAAM,CAAC,YAAP,GAAsB,IAAC,CAAA,KAAxB,CAArC;UAClB,IAAC,CAAA,MAAD,GAAU,IAAC,CAAA,KAAD,GAAS,IAAC,CAAA,cAAV,GAA2B;UACrC,IAAC,CAAA,MAAD,GAAU,IAAC,CAAA,EAAD,GAAM,IAAC,CAAA,cAAP,GAAwB;UAElC,IAAC,CAAA,YAAD,IAAiB;UAEjB,IAAG,IAAC,CAAA,YAAD,GAAgB,IAAC,CAAA,aAApB;YACE,IAAC,CAAA,MAAD,GAAU,IAAC,CAAA,YAAD,GAAgB,GAAhB,GAAsB,IAAC,CAAA,cADnC;WAAA,MAEK,IAAG,IAAC,CAAA,YAAD,GAAgB,IAAC,CAAA,aAAD,GAAiB,IAAC,CAAA,aAArC;YACH,IAAC,CAAA,MAAD,GAAU,IADP;WAAA,MAEA,IAAG,IAAC,CAAA,YAAD,GAAgB,IAAC,CAAA,aAAD,GAAiB,IAAC,CAAA,aAAlB,GAAkC,IAAC,CAAA,eAAtD;YACH,IAAC,CAAA,MAAD,GAAU,CAAC,IAAC,CAAA,aAAD,GAAiB,IAAC,CAAA,aAAlB,GAAkC,IAAC,CAAA,eAAnC,GAAqD,IAAC,CAAA,YAAvD,CAAA,GAAuE,GAAvE,GAA6E,IAAC,CAAA,gBADrF;WAAA,MAAA;YAGH,IAAC,CAAA,OAAD,GAAW,KAHR;;UAKL,IAAG,IAAC,CAAA,OAAD,KAAY,IAAf;YACE,UAAA,CAAW,IAAX,EAAc,OAAd,EAAuB,OAAvB,EADF;;UAGA,IAAC,CAAA,MAAD,IAAW,KAAA,CAAM,GAAN,EAAW,KAAA,CAAM,GAAN,EAAW,IAAC,CAAA,KAAD,GAAS,aAApB,CAAX;UACX,IAAC,CAAA,MAAD,GAAU,KAAA,CAAM,GAAN,EAAW,KAAA,CAAM,GAAN,EAAW,IAAC,CAAA,MAAZ,CAAX;QA9BF;;MAvDZ;;;yBAEE,EAAA,GAAI;;yBACJ,EAAA,GAAI;;yBACJ,EAAA,GAAI;;;yBAEJ,GAAA,GAAK;;yBACL,GAAA,GAAK;;yBACL,GAAA,GAAK;;;yBAEL,GAAA,GAAK;;yBACL,GAAA,GAAK;;yBACL,GAAA,GAAK;;;yBAEL,MAAA,GAAQ;;yBACR,MAAA,GAAQ;;;yBAER,KAAA,GAAO;;yBACP,KAAA,GAAO;;;yBAEP,KAAA,GAAO;;yBACP,KAAA,GAAO;;yBAEP,MAAA,GAAQ;;yBACR,MAAA,GAAQ;;yBAER,aAAA,GAAe;;yBACf,aAAA,GAAe;;yBACf,eAAA,GAAiB;;yBAEjB,cAAA,GAAgB;;yBAEhB,YAAA,GAAc;;yBACd,OAAA,GAAS;;;;;IAuDX,QAAA,GAAW,QAAA,CAAA,CAAA;AACT,UAAA,MAAA,EAAA;MAAA,SAAS,CAAC,SAAV,GAAsB,MAAA,GAAS,MAAM,CAAC,OAAO,CAAC,IAAf,CAAoB,GAApB,CAAT,GAAoC;MAC1D,SAAS,CAAC,QAAV,CAAmB,CAAnB,EAAsB,CAAtB,EAAyB,CAAzB,EAA4B,CAA5B;MAEA,CAAA,GAAI,OAAO,CAAC;MACZ,MAAA,GAAS;AACT,aAAM,SAAN;QACE,SAAS,CAAC,SAAV,GAAsB,OAAA,GAAU,MAAM,CAAC,MAAM,CAAC,IAAd,CAAmB,GAAnB,CAAV,GAAoC,GAApC,GAA0C,CAAC,CAAC,MAAM,CAAC,OAAT,CAAiB,CAAjB,CAA1C,GAAgE;QACtF,SAAS,CAAC,SAAV,CAAA;QACA,SAAS,CAAC,GAAV,CAAc,CAAC,CAAC,MAAhB,EAAwB,CAAC,CAAC,MAA1B,EAAkC,CAAC,CAAC,cAApC,EAAoD,CAApD,EAAuD,CAAA,GAAI,GAA3D,EAAgE,KAAhE;QACA,SAAS,CAAC,SAAV,CAAA;QACA,SAAS,CAAC,IAAV,CAAA;QACA,CAAA,GAAI,CAAC,CAAC;QACN,MAAA,IAAU;MAPZ;IANS;IAgBX,WAAA,GAAc,QAAA,CAAA,CAAA;AACZ,UAAA,YAAA,EAAA,MAAA,EAAA,CAAA,EAAA;MAAA,MAAM,CAAC,KAAP,CAAA;MACA,MAAA,GAAS,CAAC,MAAA,GAAS,GAAV,CAAA,GAAiB,CAAC,GAAA,GAAM,GAAP;MAC1B,SAAA,GAAY,KAAA,CAAM,MAAN;MACZ,SAAA,GAAY,KAAA,CAAM,MAAN;MAEZ,YAAA,GAAe;MACf,MAAA,GAAS;AACT,aAAM,YAAA,EAAA,GAAiB,MAAM,CAAC,oBAA9B;QACE,CAAA,GAAI,UAAA,CAAW,OAAO,CAAC,MAAnB,EAA2B,OAA3B,EAAoC,OAApC;QACJ,CAAC,CAAC,MAAF,CAAA;MAFF;MAIA,CAAA,GAAI,OAAO,CAAC;AACZ,aAAM,SAAN;QACE,KAAA,GAAQ,CAAC,CAAC;QACV,CAAC,CAAC,QAAF,CAAA;QACA,CAAA,GAAI;QACJ,MAAA;MAJF;MAKA,QAAA,CAAA;MAEA,MAAM,CAAC,GAAP,CAAA;aACA,uBAAA,CAAwB,QAAA,CAAA,CAAA;eAAM,WAAA,CAAA;MAAN,CAAxB;IArBY;IAuBd,WAAA,CAAA;IAEA,GAAA,GAAM,IAAI,GAAG,CAAC,GAAR,CAAA;IACN,GAAG,CAAC,GAAJ,CAAQ,MAAR,EAAgB,eAAhB,CAAgC,CAAC,GAAjC,CAAqC,EAArC,CAAwC,CAAC,GAAzC,CAA6C,GAA7C,CAAiD,CAAC,IAAlD,CAAuD,CAAvD;IACA,GAAG,CAAC,GAAJ,CAAQ,MAAR,EAAgB,eAAhB,CAAgC,CAAC,GAAjC,CAAqC,EAArC,CAAwC,CAAC,GAAzC,CAA6C,GAA7C,CAAiD,CAAC,IAAlD,CAAuD,CAAvD;IACA,GAAG,CAAC,GAAJ,CAAQ,MAAR,EAAgB,iBAAhB,CAAkC,CAAC,GAAnC,CAAuC,EAAvC,CAA0C,CAAC,GAA3C,CAA+C,GAA/C,CAAmD,CAAC,IAApD,CAAyD,CAAzD;IACA,GAAG,CAAC,GAAJ,CAAQ,MAAR,EAAgB,cAAhB,CAA+B,CAAC,GAAhC,CAAoC,GAApC,CAAwC,CAAC,GAAzC,CAA6C,IAA7C,CAAkD,CAAC,IAAnD,CAAwD,CAAxD;IACA,GAAG,CAAC,GAAJ,CAAQ,MAAR,EAAgB,sBAAhB,CAAuC,CAAC,GAAxC,CAA4C,CAA5C,CAA8C,CAAC,GAA/C,CAAmD,EAAnD,CAAsD,CAAC,IAAvD,CAA4D,CAA5D;IACA,GAAG,CAAC,GAAJ,CAAQ,MAAR,EAAgB,iBAAhB,CAAkC,CAAC,GAAnC,CAAuC,EAAvC,CAA0C,CAAC,GAA3C,CAA+C,IAA/C,CAAoD,CAAC,IAArD,CAA0D,EAA1D,CAA6D,CAAC,QAA9D,CAAuE,QAAA,CAAA,CAAA;aACrE,GAAA,GAAM,CAAC,GAAA,GAAM,GAAP,CAAA,GAAc,MAAM,CAAC;IAD0C,CAAvE;IAGA,GAAG,CAAC,QAAJ,CAAa,MAAb,EAAqB,QAArB,CAA8B,CAAC,QAA/B,CAAwC,QAAA,CAAA,CAAA;MACtC,MAAM,CAAC,MAAO,CAAA,CAAA,CAAd,GAAmB,CAAC,CAAC,MAAM,CAAC,MAAO,CAAA,CAAA;MACnC,MAAM,CAAC,MAAO,CAAA,CAAA,CAAd,GAAmB,CAAC,CAAC,MAAM,CAAC,MAAO,CAAA,CAAA;aACnC,MAAM,CAAC,MAAO,CAAA,CAAA,CAAd,GAAmB,CAAC,CAAC,MAAM,CAAC,MAAO,CAAA,CAAA;IAHG,CAAxC;IAKA,GAAG,CAAC,QAAJ,CAAa,MAAb,EAAqB,SAArB,CAA+B,CAAC,QAAhC,CAAyC,QAAA,CAAA,CAAA;MACvC,MAAM,CAAC,OAAQ,CAAA,CAAA,CAAf,GAAoB,CAAC,CAAC,MAAM,CAAC,OAAQ,CAAA,CAAA;MACrC,MAAM,CAAC,OAAQ,CAAA,CAAA,CAAf,GAAoB,CAAC,CAAC,MAAM,CAAC,OAAQ,CAAA,CAAA;aACrC,MAAM,CAAC,OAAQ,CAAA,CAAA,CAAf,GAAoB,CAAC,CAAC,MAAM,CAAC,OAAQ,CAAA,CAAA;IAHE,CAAzC;IAKA,IAAG,MAAM,CAAC,UAAP,GAAoB,IAAvB;MACE,GAAG,CAAC,KAAJ,CAAA;MACA,MAAM,CAAC,oBAAP,GAA8B,EAFhC;;IAIA,MAAM,CAAC,GAAP,GAAa;EAjPT;;EAoPN,kBAAA,CAAmB,MAAnB,EAA2B,MAA3B,EAAmC,GAAnC;AAvRA","sourcesContent":["# Hungarian notation\n# (http://en.wikipedia.org/wiki/Hungarian_notation)\n# n - HTML-Node\n# o - object\n# s - string\n# i - integer\n# a - array\n# b - boolean\n# f - float\n# p - Particle\n# fn - function\n# ctx - 2D Context\n\n# General Functions\nfnRequestAnimationFrame = (fnCallback) ->\n  fnAnimFrame =\n    window.requestAnimationFrame or\n    window.webkitRequestAnimationFrame or\n    window.mozRequestAnimationFrame or\n    window.oRequestAnimationFrame or\n    window.msRequestAnimationFrame or\n    (fnCallback) ->\n      window.setTimeOut(fnCallback, 1000 / 60)\n      return\n  fnAnimFrame fnCallback\n  return\n\n# Add Event Listener\nfnAddEventListener = (o, sEvent, fn) ->\n  if o.addEventListener\n    o.addEventListener(sEvent, fn, false)\n  else\n    o['on' + sEvent] = fn\n  return\n\napp = () ->\n\n  oStats = new Stats()\n  oStats.setMode(0)\n  oStats.domElement.style.position = 'absolute'\n  oStats.domElement.style.left = '0px'\n  oStats.domElement.style.top = '0px'\n  document.body.appendChild(oStats.domElement)\n\n  # General Elements\n  oDoc = document\n  nBody = oDoc.body\n  # Shortcuts\n  fPI = Math.PI\n  fnMax = Math.max\n  fnMin = Math.min\n  fnRnd = Math.random\n  fnRnd2 = () -> 2.0 * fnRnd() - 1.0\n  fnCos = Math.cos\n  fnACos = Math.acos\n  fnSin = Math.sin\n  # Sphere Settings\n  iRadiusSphere = 150\n  iProjSphereX = 0\n  iProjSphereY = 0\n  # Particle Settings\n  fMaxAX = 0.1\n  fMaxAY = 0.1\n  fMaxAZ = 0.1\n  fStartVX = 0.001\n  fStartVY = 0.001\n  fStartVZ = 0.001\n  fAngle = 0.0\n  fSinAngle = 0.0\n  fCosAngle = 0.0\n\n  window.iFramesToRotate = 2100.0\n  window.iPerspective = 220\n  window.iNewParticlePerFrame = 4\n  window.fGrowDuration = 120.0\n  window.fWaitDuration = 340.0\n  window.fShrinkDuration = 430.0\n  window.aColor = [0, 126, 255]\n  window.bgColor = [255, 255, 255]\n\n  fVX = (2.0 * fPI) / window.iFramesToRotate\n\n  oRadGrad = null\n  ctxRender = nCanvasRender.getContext '2d'\n\n\n  oRender = {pFirst: null}\n  oBuffer = {pFirst: null}\n  \n  w = h = 0\n\n  # gets/sets size\n  fnSetSize = () ->\n    nCanvasRender.width = w = window.innerWidth\n    nCanvasRender.height = h = window.innerHeight\n    iProjSphereX = w / 2\n    iProjSphereY = h / 2\n    {w: w, h: h}\n\n  fnSetSize()\n  \n  # window.onresize\n  fnAddEventListener(window, 'resize', fnSetSize)\n\n  fnSwapList = (p, oSrc, oDst) ->\n    if p?\n      # remove p from oSrc\n      if oSrc.pFirst is p\n        oSrc.pFirst = p.pNext\n        p.pNext.pPrev = null if p.pNext?\n      else\n        p.pPrev.pNext = p.pNext\n        p.pNext.pPrev = p.pPrev if p.pNext?\n    else\n      # create new p\n      p = new Particle()\n  \n    p.pNext = oDst.pFirst\n    oDst.pFirst.pPrev = p if oDst.pFirst?\n    oDst.pFirst = p\n    p.pPrev = null\n    p\n  \n  # Particle\n  class Particle\n    # Current Position\n    fX: 0.0\n    fY: 0.0\n    fZ: 0.0\n    # Current Velocity\n    fVX: 0.0\n    fVY: 0.0\n    fVZ: 0.0\n    # Current Acceleration\n    fAX: 0.0\n    fAY: 0.0\n    fAZ: 0.0\n    # Projection Position\n    fProjX: 0.0\n    fProjY: 0.0\n    # Rotation\n    fRotX: 0.0\n    fRotZ: 0.0\n    # double linked list\n    pPrev: null\n    pNext: null\n    \n    fAngle: 0.0\n    fForce: 0.0\n\n    fGrowDuration: 0.0\n    fWaitDuration: 0.0\n    fShrinkDuration: 0.0\n    \n    fRadiusCurrent: 0.0\n    \n    iFramesAlive: 0\n    bIsDead: false\n      \n    fnInit: () ->\n      @fAngle = fnRnd() * fPI * 2\n      @fForce = fnACos(fnRnd2())\n      @fAlpha = 0\n      @bIsDead = false;\n      @iFramesAlive = 0;\n      @fX = iRadiusSphere * fnSin(@fForce) * fnCos(@fAngle)\n      @fY = iRadiusSphere * fnSin(@fForce) * fnSin(@fAngle)\n      @fZ = iRadiusSphere * fnCos(@fForce)\n      @fVX = fStartVX * @fX\n      @fVY = fStartVY * @fY\n      @fVZ = fStartVZ * @fZ\n      @fGrowDuration = window.fGrowDuration + fnRnd2() * (window.fGrowDuration / 4.0)\n      @fWaitDuration = window.fWaitDuration + fnRnd2() * (window.fWaitDuration / 4.0)\n      @fShrinkDuration = window.fShrinkDuration + fnRnd2() * (window.fShrinkDuration / 4.0)\n      @fAX = 0.0\n      @fAY = 0.0\n      @fAZ = 0.0\n      return\n  \n    fnUpdate: () ->\n      if @iFramesAlive > @fGrowDuration + @fWaitDuration\n        @fVX += @fAX + fMaxAX * fnRnd2()\n        @fVY += @fAY + fMaxAY * fnRnd2()\n        @fVZ += @fAZ + fMaxAZ * fnRnd2()\n        @fX += @fVX\n        @fY += @fVY\n        @fZ += @fVZ\n\n      @fRotX = fCosAngle * @fX + fSinAngle * @fZ\n      @fRotZ = -fSinAngle * @fX + fCosAngle * @fZ\n      @fRadiusCurrent = Math.max(0.01, window.iPerspective / (window.iPerspective - @fRotZ))\n      @fProjX = @fRotX * @fRadiusCurrent + iProjSphereX \n      @fProjY = @fY * @fRadiusCurrent + iProjSphereY \n\n      @iFramesAlive += 1\n\n      if @iFramesAlive < @fGrowDuration\n        @fAlpha = @iFramesAlive * 1.0 / @fGrowDuration\n      else if @iFramesAlive < @fGrowDuration + @fWaitDuration\n        @fAlpha = 1.0\n      else if @iFramesAlive < @fGrowDuration + @fWaitDuration + @fShrinkDuration\n        @fAlpha = (@fGrowDuration + @fWaitDuration + @fShrinkDuration - @iFramesAlive) * 1.0 / @fShrinkDuration\n      else\n        @bIsDead = true\n\n      if @bIsDead is true\n        fnSwapList(@, oRender, oBuffer)\n\n      @fAlpha *= fnMin(1.0, fnMax(0.5, @fRotZ / iRadiusSphere))\n      @fAlpha = fnMin(1.0, fnMax(0.0, @fAlpha))\n      return\n      \n  fnRender = () ->\n    ctxRender.fillStyle = \"rgb(\" + window.bgColor.join(',') + \")\"\n    ctxRender.fillRect(0, 0, w, h)\n\n    p = oRender.pFirst\n    iCount = 0\n    while p?\n      ctxRender.fillStyle = \"rgba(\" + window.aColor.join(',') + ',' + p.fAlpha.toFixed(4) + \")\"\n      ctxRender.beginPath()\n      ctxRender.arc(p.fProjX, p.fProjY, p.fRadiusCurrent, 0, 2 * fPI, false)\n      ctxRender.closePath()\n      ctxRender.fill()\n      p = p.pNext\n      iCount += 1\n    return\n  \n  fnNextFrame = () ->\n    oStats.begin()\n    fAngle = (fAngle + fVX) % (2.0 * fPI)\n    fSinAngle = fnSin(fAngle)\n    fCosAngle = fnCos(fAngle)\n\n    iAddParticle = 0\n    iCount = 0\n    while iAddParticle++ < window.iNewParticlePerFrame\n      p = fnSwapList(oBuffer.pFirst, oBuffer, oRender)\n      p.fnInit()\n  \n    p = oRender.pFirst\n    while p?\n      pNext = p.pNext\n      p.fnUpdate()\n      p = pNext\n      iCount++\n    fnRender()\n\n    oStats.end()\n    fnRequestAnimationFrame () -> fnNextFrame() \n    \n  fnNextFrame()  \n\n  gui = new dat.GUI();\n  gui.add(window, 'fGrowDuration').min(10).max(500).step(1)\n  gui.add(window, 'fWaitDuration').min(10).max(500).step(1)\n  gui.add(window, 'fShrinkDuration').min(10).max(500).step(1)\n  gui.add(window, 'iPerspective').min(150).max(1000).step(1)\n  gui.add(window, 'iNewParticlePerFrame').min(1).max(20).step(1)\n  gui.add(window, 'iFramesToRotate').min(50).max(2500).step(50).onChange(() ->\n    fVX = (2.0 * fPI) / window.iFramesToRotate\n  )\n  gui.addColor(window, 'aColor').onChange(() ->\n    window.aColor[0] = ~~window.aColor[0]\n    window.aColor[1] = ~~window.aColor[1]\n    window.aColor[2] = ~~window.aColor[2]\n  )\n  gui.addColor(window, 'bgColor').onChange(() ->\n    window.bgColor[0] = ~~window.bgColor[0]\n    window.bgColor[1] = ~~window.bgColor[1]\n    window.bgColor[2] = ~~window.bgColor[2]\n  )\n  if window.innerWidth < 1000\n    gui.close()\n    window.iNewParticlePerFrame = 5\n\n  window.app = @\n  return\n  \nfnAddEventListener(window, 'load', app)"]} | |
//# sourceURL=coffeescript |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment