anxiety/scripts/game/BG_Anxiety.js

120 lines
2.4 KiB
JavaScript

/******************************
A cool floating-squares dark background...
or maybe CA?
******************************/
function BG_Anxiety(whiteMode){
var self = this;
self.whiteMode = whiteMode;
// Moving white boxes
var BG_WIDTH = 360;
var BG_HEIGHT = 450;
self.boxes = [];
self.resetBox = function(box, startInView){
// Random size
box.w = box.h = Math.random()*200 + 100;
// Start in view?
if(startInView){
// Random position
box.x = Math.random()*(BG_WIDTH+box.w*2) - box.w;
box.y = Math.random()*(BG_HEIGHT+box.h*2) - box.h;
}
// Move horizontal-only or vertical-only
if(Math.random()<0.5){
box.velX = (Math.random()>0.5 ? -1 : 1) * (Math.random()*0.8+0.2);
box.velY = 0;
}else{
box.velX = 0;
box.velY = (Math.random()>0.5 ? -1 : 1) * (Math.random()*0.8+0.2);
}
// If NOT start in view, use Velocity to determine where to put box
if(!startInView){
// Horizontal
if(box.velY==0){
box.y = Math.random()*(BG_HEIGHT+box.h*2) - box.h;
if(box.velX>0){ // ltr
box.x = -box.w;
}else{ // rtl
box.x = BG_WIDTH;
}
}
// Vertical
if(box.velX==0){
box.x = Math.random()*(BG_WIDTH+box.w*2) - box.w;
if(box.velY>0){ // utd
box.y = -box.h;
}else{ // dtu
box.y = BG_HEIGHT;
}
}
}
};
self.isBoxOutOfSight = function(box){
if(box.x<-box.w) return true;
if(box.y<-box.h) return true;
if(box.x>BG_WIDTH) return true;
if(box.y>BG_HEIGHT) return true;
return false;
};
self.updateBox = function(box){
// Move it
box.x += box.velX;
box.y += box.velY;
// If it's out of sight, reset it
if(self.isBoxOutOfSight(box)){
self.resetBox(box);
}
};
self.drawBox = function(box, ctx){
ctx.fillStyle = self.whiteMode ? "rgba(255,255,255,0.1)" : "rgba(255,255,255,0.03)";
ctx.fillRect(box.x, box.y, box.w, box.h);
};
for(var i=0; i<40; i++){
var box = {};
self.resetBox(box, true);
self.boxes.push(box);
}
var allBoxAlpha = 0;
self.update = function(alpha){
allBoxAlpha = alpha;
self.boxes.forEach(function(box){
self.updateBox(box);
});
};
self.draw = function(ctx){
// A big ol' black box
ctx.fillStyle = self.whiteMode ? "#dddddd" : "#111111";
ctx.fillRect(0,0, BG_WIDTH, BG_HEIGHT);
// All-box alpha
// allBoxAlpha += 1/30;
// if(allBoxAlpha>1) allBoxAlpha=1;
// Moving white boxes
ctx.globalAlpha = allBoxAlpha;
self.boxes.forEach(function(box){
self.drawBox(box, ctx);
});
ctx.globalAlpha = 1;
};
}