Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- var aaSnowConfig = {snowflakes: '200'}; // number of snowflakes
- var garlandMode = 0; // 0 - Default, 1 - Round Robin, 2 - Double Lights, 3 - All Lights
- var garlandSpeed = 600; //ms
- // dynamic speed:
- // do speed correction every speedCorrectionFrames frames
- var speedCorrectionFrames = 60;
- var currentSpeedCorrectionFrame = 0;
- // start without any speed correction
- var speedFactor = .8;
- // fall down to this value at most
- var minSpeedFactor = 0.1;
- // get fast at this value at most
- var maxSpeedFactor = 1.5;
- // don't set value immidietly change gradually by this amount
- var speedFactorDelta = 0.05;
- var snowStyle = `
- <style type='text/css'>
- #garland {
- position: absolute;
- top: 0;
- left: 0;
- z-index: 500;
- background-image: url('');
- height: 36px;
- width: 100%;
- overflow: hidden;
- z- index: 99;
- }
- #nums_1 {
- padding: 100px;
- }
- .garland_1 {
- background-position: 0 0;
- }
- .garland_2 {
- background-position: 0 -36px;
- }
- .garland_3 {
- background-position: 0 -72px;
- }
- .garland_4 {
- background-position: 0 -108px;
- }
- .garland_5 {
- background-position: 0 -144px;
- }
- .garland_6 {
- background-position: 0 -180px;
- }
- .garland_7 {
- background-position: 0 -216px;
- }
- .garland_8 {
- background-position: 0 -252px;
- }
- </style>
- `
- $('head').append(snowStyle);
- $('body').prepend(`
- <div id="garland" class="garland_4">
- <div id="nums_1">1</div>
- </div>
- `);
- function garland() {
- var nums = document.getElementById('nums_1').innerHTML;
- if(garlandMode <= 0){
- document.getElementById('garland').className = 'garland_'+nums;
- if(++nums >= 9) nums = 1;
- document.getElementById('nums_1').innerHTML = nums;
- }
- else if(garlandMode === 1){
- document.getElementById('garland').className = 'garland_'+nums;
- if(++nums >= 6) nums = 2;
- document.getElementById('nums_1').innerHTML = nums;
- }
- else if(garlandMode === 2){
- if(nums < 7) nums = 6;
- document.getElementById('garland').className = 'garland_'+nums;
- if(++nums == 8) nums = 6;
- document.getElementById('nums_1').innerHTML = nums;
- }
- else{
- if(nums == 1){
- document.getElementById('garland').className = 'garland_8';
- document.getElementById('nums_1').innerHTML = '8';
- }
- else{
- document.getElementById('garland').className = 'garland_1';
- document.getElementById('nums_1').innerHTML = '1';
- }
- }
- setTimeout(garland, garlandSpeed);
- };
- garland();
- var idleTimeout = 1000,
- idleNow = false,
- idleTimestamp = null,
- idleTimer = null;
- function setIdleTimeout(ms) {
- idleTimeout = ms;
- idleTimestamp = new Date().getTime() + ms;
- if (idleTimer != null) {
- clearTimeout(idleTimer);
- }
- idleTimer = setTimeout(makeIdle, ms + 50);
- }
- function makeIdle() {
- var t = new Date().getTime();
- if (t < idleTimestamp) {
- idleTimer = setTimeout(makeIdle, idleTimestamp - t + 50);
- return;
- }
- // console.log('** IDLE **');
- idleNow = true;
- try {
- if (document.onIdle) document.onIdle();
- } catch (err) {}
- }
- function active(event) {
- var t = new Date().getTime();
- idleTimestamp = t + idleTimeout;
- // console.log('not idle.');
- if (idleNow) {
- setIdleTimeout(idleTimeout);
- }
- // console.log('** BACK **');
- if ((idleNow) && document.onBack) document.onBack(idleNow);
- idleNow = false;
- }
- var doc = jQuery(document);
- doc.ready(function () {
- doc.mousemove(active);
- try {
- doc.mouseenter(active);
- } catch (err) {}
- try {
- doc.scroll(active);
- } catch (err) {}
- try {
- doc.keydown(active);
- } catch (err) {}
- try {
- doc.click(active);
- } catch (err) {}
- try {
- doc.dblclick(active);
- } catch (err) {}
- });
- Snowflakes = (function () {
- "use strict";
- // snowflakes objects collection
- var snowflakes = [];
- var snowflakesDefaultCount = 1000;
- // if true - we'll guess the best number of snowflakes for the system
- var dynamicSnowflakesCount = false;
- // we increment snowflakes with this rate
- var snowflakeCountIncrement = 0.1;
- // we can remove aggressively (to quicker free system resources), basically we remove at snowflakeCountIncrement*snowflakeRemoveFactor rate
- var snowflakeRemoveFactor = 2;
- // snowflakes sprites
- var snowflakeSpritesLocation = "";
- var snowflakeSprites = [];
- var spritesCount = 5;
- var spriteWidth = 20;
- var spriteHeight = 20;
- // canvas bounds used for snowflake animation
- var bounds = {
- width: window.innerWidth,
- height: window.innerHeight
- };
- // particle movement parameters:
- // we'll advance each particle vertically at least by this amount (think gravity and resistance)
- var minVerticalVelocity = 1;
- // we'll advance each particle vertically at most by this amount (think gravity and resistance)
- var maxVerticalVelocity = 4;
- // we'll shift each particle horizontally at least by this amound (think wind and resistance)
- var minHorizontalVelocity = -1;
- // we'll shift each particle horizontally at least by this amound (think wind and resistance)
- var maxHorizontalVelocity = 3;
- // each particle sprite will be scaled down maxScale / this (this < maxScale) at max
- var minScale = 0.2;
- // each particle sprite will be scaled down this / minScale (this > minScale) at max
- var maxScale = 1.25;
- // each particle also "bobs" on horizontal axis (think volumetric resistance) by this amount at least
- var minHorizontalDelta = 2;
- // each particle also "bobs" on horizontal axis (think volumetric resistance) by this amount at most
- var maxHorizontalDelta = 3;
- // each particle is at least this opaque
- var minOpacity = 0.2;
- // each particle is at least this opaque
- var maxOpacity = 0.9;
- // change opacity by at max 1/maxOpacityIncrement
- var maxOpacityIncrement = 50;
- // create number of snowflakes adding if required (or regenerate from scratch)
- function generate(number, add) {
- // initialize sprite
- var image = new Image();
- image.onload = function () {
- for (var ii = 0; ii < spritesCount; ii++) {
- var sprite = document.createElement("canvas");
- sprite.width = spriteWidth;
- sprite.height = spriteHeight;
- var context = sprite.getContext("2d");
- context.drawImage(
- // source image
- image,
- // source x
- ii * spriteWidth,
- // source y
- 0,
- // source width
- spriteWidth,
- // source height
- spriteHeight,
- // target x
- 0,
- //target y
- 0,
- // target width
- spriteWidth,
- // target height
- spriteHeight);
- snowflakeSprites.push(sprite);
- }
- if (number) {
- snowflakesDefaultCount = number;
- }
- if (!add) {
- snowflakes = [];
- }
- for (var ii = 0; ii < snowflakesDefaultCount; ii++) {
- snowflakes.push(generateSnowflake());
- }
- }
- image.src = snowflakeSpritesLocation;
- }
- function generateSnowflake() {
- var scale = Math.random() * (maxScale - minScale) + minScale;
- return {
- // x position
- x: Math.random() * bounds.width,
- // y position
- y: Math.random() * bounds.height,
- // vertical velocity
- vv: Math.random() * (maxVerticalVelocity - minVerticalVelocity) + minVerticalVelocity,
- // horizontal velocity
- hv: Math.random() * (maxHorizontalVelocity - minHorizontalVelocity) + minHorizontalVelocity,
- // scaled sprite width
- sw: scale * spriteWidth,
- // scaled sprite width
- sh: scale * spriteHeight,
- // maximum horizontal delta
- mhd: Math.random() * (maxHorizontalDelta - minHorizontalDelta) + minHorizontalDelta,
- // horizontal delta
- hd: 0,
- // horizontal delta increment
- hdi: Math.random() / (maxHorizontalVelocity * minHorizontalDelta),
- // opacity
- o: Math.random() * (maxOpacity - minOpacity) + minOpacity,
- // opacity increment
- oi: Math.random() / maxOpacityIncrement,
- // sprite index
- si: Math.ceil(Math.random() * (spritesCount - 1)),
- // not landing flag
- nl: false
- }
- }
- // help snowflakes fall
- function advanceSnowFlakes() {
- for (var ii = 0; ii < snowflakes.length; ii++) {
- var sf = snowflakes[ii];
- // we obey the gravity, 'cause it's the law
- sf.y += sf.vv * speedFactor;
- // while we're obeying the gravity, we do it with style
- sf.x += (sf.hd + sf.hv) * speedFactor;
- // advance horizontal axis "bobbing"
- sf.hd += sf.hdi;
- // inverse "bobbing" direction if we get to maximum delta limit
- if (sf.hd < -sf.mhd || sf.hd > sf.mhd) {
- sf.hdi = -sf.hdi;
- };
- // increment opacity and check opacity value bounds
- sf.o += sf.oi;
- if (sf.o > maxOpacity || sf.o < minOpacity) {
- sf.oi = -sf.oi
- };
- if (sf.o > maxOpacity) sf.o = maxOpacity;
- if (sf.o < minOpacity) sf.o = minOpacity;
- // return within dimensions bounds if we've crossed them
- // and don't forget to reset the not-landing (sf.nl) flag
- var resetNotLanding = false;
- if (sf.y > bounds.height + spriteHeight / 2) {
- sf.y = 0
- resetNotLanding = true;
- };
- if (sf.y < 0) {
- sf.y = bounds.height
- resetNotLanding = true;
- };
- if (sf.x > bounds.width + spriteWidth / 2) {
- sf.x = 0
- resetNotLanding = true;
- };
- if (sf.x < 0) {
- sf.x = bounds.width
- resetNotLanding = true;
- };
- if (resetNotLanding) {
- sf.nl = false;
- }
- }
- }
- // not using, but it allows to increase/decrease speed based on fps
- // in essence - visual feedback on fps value
- function adjustSpeedFactor() {
- if (++currentSpeedCorrectionFrame === speedCorrectionFrames) {
- var lastFps = SystemInformation.getLastFps();
- var targetSpeedFactor = (lastFps * (maxSpeedFactor - minSpeedFactor) / 60) + minSpeedFactor;
- speedFactor += (targetSpeedFactor < speedFactor) ? -speedFactorDelta : speedFactorDelta;
- if (speedFactor > maxSpeedFactor) {
- speedFactor = maxSpeedFactor;
- }
- if (speedFactor < minSpeedFactor) {
- speedFactor = minSpeedFactor;
- }
- currentSpeedCorrectionFrame = 0;
- }
- }
- function renderFrame(context) {
- // fall down one iteration
- advanceSnowFlakes();
- // clear context and save it
- context.canvas.width = window.innerWidth;
- context.canvas.height = window.innerHeight;
- context.clearRect(0, 0, context.canvas.width, context.canvas.height);
- for (var ii = 0; ii < snowflakes.length; ii++) {
- var sf = snowflakes[ii];
- context.globalAlpha = sf.o;
- context.drawImage(
- // image
- snowflakeSprites[sf.si],
- // source x
- 0,
- // source y
- 0,
- // source width
- spriteWidth,
- // source height
- spriteHeight,
- // target x
- sf.x,
- // target y
- sf.y,
- // target width
- sf.sw,
- // target height
- sf.sh);
- }
- }
- function updateBounds() {
- bounds.width = window.innerWidth;
- bounds.height = window.innerHeight;
- }
- function count() {
- return snowflakes.length;
- }
- // increase number of falling snowflakes
- // the default increase is snowflakeCountIncrement
- function add(number) {
- if (!number) {
- number = snowflakes.length * snowflakeCountIncrement;
- }
- generate(number, true);
- }
- // remove some snowflakes
- // by default we remove more aggressively to free resources faster
- function remove(number) {
- if (!number) {
- number = snowflakes.length * snowflakeCountIncrement * snowflakeRemoveFactor;
- }
- if (snowflakes.length - number > 0) {
- snowflakes = snowflakes.slice(0, snowflakes.length - number);
- }
- }
- return {
- "generate": generate,
- "add": add,
- "remove": remove,
- "render": renderFrame,
- "count": count,
- "updateBounds": updateBounds,
- "dynamicSnowflakesCount": dynamicSnowflakesCount
- }
- })();
- // single animation loop and fps calculation
- Animation = (function () {
- "use strict";
- // collection of function to render single frame (snowflakes falling, background gradient animation)
- var frameRenderersCollection = [];
- // each animation should be rendered on corresponding context.
- // If animation doesn't have context (non-visual parameter change every frame) - it should be last (several framerenderers can be last without contexts)
- var renderContextesCollection = [];
- // if animation is running
- var isRunning = false;
- // show debug
- var debug = false;
- // callback pointer for cancelling
- var animationCallback;
- // if browser doesn't support requestAnimationFrame - we use setInterval for 60Hz displays (16.7ms per frame)
- var minInterval = 16.7;
- // fps tracking
- var avgTime = 0;
- var trackFrames = 60;
- var frameCounter = 0;
- // register new renderer and corresponding context
- function addFrameRenderer(frameRender, renderContext) {
- if (frameRender && typeof (frameRender) === "function") {
- frameRenderersCollection.push(frameRender);
- renderContextesCollection.push(renderContext);
- }
- }
- // detecting requestAnimationFrame feature
- function getRequestAnimationFrame(code) {
- if (window.requestAnimationFrame) {
- return window.requestAnimationFrame(code);
- } else if (window.msRequestAnimationFrame) {
- return window.msRequestAnimationFrame(code);
- } else if (window.webkitRequestAnimationFrame) {
- return window.webkitRequestAnimationFrame(code);
- } else if (window.mozRequestAnimationFrame) {
- return window.mozRequestAnimationFrame(code);
- } else {
- return setTimeout(code, minInterval);
- }
- }
- // iterate and render all registered renderers
- function frameRenderCore() {
- var startDate = new Date();
- for (var ii = 0; ii < frameRenderersCollection.length; ii++) {
- if (frameRenderersCollection[ii]) {
- frameRenderersCollection[ii](renderContextesCollection[ii]);
- }
- }
- if (isRunning) {
- animationCallback = getRequestAnimationFrame(frameRenderCore);
- }
- var endDate = new Date();
- var duration = (endDate - startDate);
- avgTime += duration;
- // we count fps every trackFrames frame
- frameCounter++;
- if (frameCounter >= trackFrames) {
- avgTime = avgTime / trackFrames;
- var avgFps = Math.floor(1000 / avgTime);
- if (avgFps > 60) avgFps = 60;
- if (debug === true) {
- // update fps information and snowflake count if dynamic
- console.log({
- fps: avgFps,
- snowflakes: (Snowflakes.dynamicSnowflakesCount) ? Snowflakes.count() : ""
- });
- }
- avgTime = 0;
- frameCounter = 0;
- }
- }
- // playback control: play, pause, toggle
- function start() {
- if (isRunning) return;
- animationCallback = getRequestAnimationFrame(frameRenderCore);
- isRunning = true;
- }
- function stop() {
- if (!isRunning) return;
- clearInterval(animationCallback);
- isRunning = false;
- }
- function toggle() {
- var playbackControl = (isRunning) ? stop : start;
- playbackControl();
- }
- return {
- "addFrameRenderer": addFrameRenderer,
- "start": start,
- "stop": stop,
- "toggle": toggle,
- "getRequestAnimationFrame": getRequestAnimationFrame
- }
- })();
- // Initialization and events code for the app
- (function () {
- "use strict";
- // preparing the elements we'll need further
- var snowflakesCanvas = null;
- var snowflakesContext = null;
- function resizeCanvasElements() {
- // resize falling snowflakes canvas to fit the screen
- Snowflakes.updateBounds();
- }
- function snowInit() {
- snowflakesCanvas = jQuery('<canvas id="snowflakesCanvas" />');
- jQuery('body').prepend(snowflakesCanvas);
- snowflakesCanvas = document.getElementById("snowflakesCanvas");
- snowflakesContext = snowflakesCanvas.getContext("2d");
- // initialiaze the Snowflakes
- Snowflakes.generate(aaSnowConfig.snowflakes);
- // initialize out animation functions and start animation:
- // falling snowflakes
- Animation.addFrameRenderer(Snowflakes.render, snowflakesContext);
- // start the animation
- Animation.start();
- if (aaSnowConfig.play_sound == true) {
- // start audio
- playAudio.init(aaSnowConfig.volume, aaSnowConfig.mp3, aaSnowConfig.ogg);
- playAudio.play();
- }
- if (aaSnowConfig.hideUnderContentBlock != "") {
- var jQSnow = jQuery(snowflakesCanvas);
- var jQContent = jQuery(aaSnowConfig.hideUnderContentBlock),
- zInx = jQSnow.css('z-index');
- // set idle time out
- setIdleTimeout(1000);
- // go to idle function
- document.onIdle = function () {
- jQSnow.show();
- jQSnow.css('z-index', 9999);
- }
- // back from idle function
- document.onBack = function (isIdle) {
- if (isIdle) {
- if (aaSnowConfig.hideUnderContentBlock == false) {
- jQSnow.hide();
- } else {
- jQSnow.css('z-index', -1);
- }
- };
- }
- }
- // properly resize the canvases
- resizeCanvasElements();
- };
- snowInit();
- window.addEventListener("resize", function () {
- // properly resize the canvases
- resizeCanvasElements();
- });
- })();
- $(window).resize(function(){
- setTimeout(function(){
- var width = $(MPP.piano.rootElement).width();
- var height = Math.floor(width * 0.2);
- $(MPP.piano.rootElement).css({marginTop: Math.floor($(window).height() / 2 - height / 2) - $("#snowflakesCanvas").height() + "px"});
- var left = +$(MPP.piano.rootElement).css("margin-left").slice(0, -2);
- var b6Key = MPP.piano.keys.b6.rect;
- $("#garland").css({marginTop: Math.floor($(window).height() / 2 - height / 2) + "px", width: b6Key.x2 + b6Key.w + "px", marginLeft: left + left*50/100});
- },100);
- });
- setTimeout(function(){$(window).resize();},100);
Comments
-
- it didnt work.
-
- Hi. That's strange. When I go to MultiplayerPiano.com or MPPClone.com and paste this script into the console, it runs fine in either case. Can you tell me what's being displayed in the console after you run this script?
Add Comment
Please, Sign In to add comment