cdf
Version:
A library for creating oldschool demo-like animations with JavaScript
349 lines (286 loc) • 42.3 kB
JavaScript
/*! The original of this file was done by TotorMan... ;) */
(function (global) {
var lib = global.cdf || {};
var decrunch = lib.decrunch || {};
decrunch.amiga = function(DType, MaxBarHeight, StartDecrunchAt, DecrunchMaxVBL) {
function get_random_color() {
var letters = '0123456789ABCDEF'.split('');
var color = '';
for (var i = 0; i < 6; i++) {
color += letters[Math.round(Math.random() * 15)];
}
return '#' + color;
}
// Amiga shell window
this.amigashell = new Image();
// base64 encoded PNG
this.amigashell.src = "";
// Mouse, Cursor, black parts of shell window
this.amigashelltop = new Image();
// base64 encoded PNG
this.amigashelltop.src = "";
// Total time for the decrunch effect
this.DecrunchMaxVBL = DecrunchMaxVBL;
// Current decrunch vbl counter
this.DecrunchVBLs = 0;
// Before that point, only shell window, after that point, decrunch visible
this.StartDecrunchAt = StartDecrunchAt;
// Decrunch types
this.NoAmigaShell = 0; // bars are full screen
this.AmigaShellBlink = 1; // bars are on the Amiga Shell white lines
this.AmigaShellOver = 2; // bars are behind the Amiga Shell white lines
this.AmigaShellOverPalette = 3; // bars are behind the Amiga Shell and uses a custom Palette
this.NoAmigaShellPalette = 4; // bars are full screen and uses a custom Palette
// user choice decrunch type
this.DType = DType;
this.palette = new Array();
// base siez of decruch bar
this.MaxBarHeight = MaxBarHeight;
// working canvas
this.mycanvas_temp = new canvas(720, 512)
// = 1 when all is done
this.finished = 0;
this.doDecrunch = function (dest) {
// working canvas sizes
var W = this.mycanvas_temp.contex.canvas.width;
var H = this.mycanvas_temp.contex.canvas.height;
// images sizes
var w1 = this.amigashell.width;
var h1 = this.amigashell.height;
var w2 = this.amigashelltop.width;
var h2 = this.amigashelltop.height;
// Before decrunch we only draw the Amiga shell window
if (this.DecrunchVBLs < this.StartDecrunchAt) {
this.mycanvas_temp.contex.drawImage(this.amigashell, 40, 16, w1, h1);
this.mycanvas_temp.contex.drawImage(this.amigashelltop, 40, 16, w2, h2);
} else {
// We will parse y
var y = 0;
// While not parsed all height of working canvas
while (y <= H) {
// calculate color bar height
var barh = (1 + Math.random()) * this.MaxBarHeight;
// draws the bar
var mycolor;
if (((this.DType == this.AmigaShellOverPalette) || (this.DType == this.NoAmigaShellPalette)) && (this.palette.length > 0)) {
mycolor = this.palette[Math.round(Math.random() * this.palette.length)];
} else {
mycolor = get_random_color();
}
this.mycanvas_temp.contex.fillStyle = mycolor;
this.mycanvas_temp.contex.fillRect(0, y, W, barh);
// next bar
y += barh;
}
// if Amiga shell window is the only thing that must blink
if (this.DType == this.AmigaShellBlink) {
// set destination-in canvas mode
this.mycanvas_temp.contex.globalCompositeOperation = 'destination-in';
// draw the Amiga shell window
this.mycanvas_temp.contex.drawImage(this.amigashell, 40, 16, w1, h1);
// back to normal mode
this.mycanvas_temp.contex.globalCompositeOperation = 'source-over';
// draw front things (mouse, cursor, ...)
this.mycanvas_temp.contex.drawImage(this.amigashelltop, 40, 16, w2, h2);
}
// if bars must appear behind the amiga shell window
if ((this.DType == this.AmigaShellOver) || (this.DType == this.AmigaShellOverPalette)) {
// draw the images over the bars
this.mycanvas_temp.contex.drawImage(this.amigashell, 40, 16, w1, h1);
this.mycanvas_temp.contex.drawImage(this.amigashelltop, 40, 16, w2, h2);
}
}
// put destination canvas into no AA mode
dest.contex.ImageSmoothingEnabled = false;
dest.contex.webkitImageSmoothingEnabled = false;
dest.contex.mozImageSmoothingEnabled = false;
dest.contex.oImageSmoothingEnabled = false;
// the famous Amiga background blue color
dest.fill('#0055AD');
// calculate the destination scale
var scx = dest.contex.canvas.width / W;
var scy = dest.contex.canvas.height / H;
// draw that decrunch
this.mycanvas_temp.draw(dest, 0, 0, 1, 0, scx, scy);
// next frame please
this.DecrunchVBLs++;
// are we finished ?
if (this.DecrunchVBLs >= this.DecrunchMaxVBL) {
this.finished = 1;
}
}
return this;
}
decrunch.atari = function(DType, MaxBarHeight, StartDecrunchAt, DecrunchMaxVBL) {
// Automation logo
this.automation = new Image();
// base64 encoded PNG
this.automation.src = "";
// the famous bee mouse cursor
this.bee = new Image();
// base64 encoded PNG
this.bee.src = "";
// Total time for the decrunch effect
this.DecrunchMaxVBL = DecrunchMaxVBL;
// Current decrunch vbl counter
this.DecrunchVBLs = 0;
// Before that point, only shell window, after that point, decrunch visible
this.StartDecrunchAt = StartDecrunchAt;
// Decrunch types
this.AtariAutomation = 0; // Automation Packer v2.3r
this.AtariPalette = 1; // user gives its own palette
this.palette = new Array();
// user choice decrunch type
this.DType = DType;
// base size of decruch bar
this.MaxBarHeight = MaxBarHeight;
// working canvas
this.mycanvas_temp = new canvas(640, 480)
// = 1 when all is done
this.finished = 0;
this.doDecrunch = function (dest) {
// working canvas sizes
var W = this.mycanvas_temp.contex.canvas.width;
var H = this.mycanvas_temp.contex.canvas.height;
// We will parse y
var y = 0;
// if Atari Automation Packer is selected
if ((this.DType == this.AtariAutomation) || (this.DType == this.AtariPalette)) {
// images sizes
var w1 = this.automation.width;
var h1 = this.automation.height;
var w2 = this.bee.width;
var h2 = this.bee.height;
if ((this.DType == this.AtariAutomation) || (this.palette.length == 0)) {
this.palette = Array('#a0b000', '#a0a000', '#a02010', '#a02090', '#a0c030', '#a0d0a0', '#a04000', '#a080a0', '#a08000', '#a000f0', '#a0d060', '#a0a0a0');
}
var tmp1 = 10 + Math.round(Math.random() * this.MaxBarHeight);
// While not parsed all height of working canvas
while (y <= H) {
// calculate color bar height
var barh = Math.round(Math.random() * tmp1);
var col = Math.round(Math.random() * 12);
// draws the bar
this.mycanvas_temp.contex.fillStyle = this.palette[col];
this.mycanvas_temp.contex.fillRect(0, y, W, barh);
// next bar
y += barh;
}
// draw the images over the bars
this.mycanvas_temp.contex.drawImage(this.automation, 320 - w1 / 2, 7, w1, h1);
this.mycanvas_temp.contex.drawImage(this.bee, 320, 50, w2, h2);
}
// put destination canvas into no AA mode
dest.contex.ImageSmoothingEnabled = false;
dest.contex.webkitImageSmoothingEnabled = false;
dest.contex.mozImageSmoothingEnabled = false;
dest.contex.oImageSmoothingEnabled = false;
// calculate the destination scale
var scx = dest.contex.canvas.width / W;
var scy = dest.contex.canvas.height / H;
// draw that decrunch
this.mycanvas_temp.draw(dest, 0, 0, 1, 0, scx, scy);
// next frame please
this.DecrunchVBLs++;
// are we finished ?
if (this.DecrunchVBLs >= this.DecrunchMaxVBL) {
this.finished = 1;
}
}
return this;
}
decrunch.dos = function(DType, MaxBarHeight, StartDecrunchAt, DecrunchMaxVBL) {
function get_random_color() {
var letters = '0123456789ABCDEF'.split('');
var color = '';
for (var i = 0; i < 6; i++) {
color += letters[Math.round(Math.random() * 15)];
}
return '#' + color;
}
// DOS shell window
this.DOSshell = new Image();
// base64 encoded PNG
this.DOSshell.src = "";
// Total time for the decrunch effect
this.DecrunchMaxVBL = DecrunchMaxVBL;
// Current decrunch vbl counter
this.DecrunchVBLs = 0;
// Before that point, only shell window, after that point, decrunch visible
this.StartDecrunchAt = StartDecrunchAt;
// Decrunch types
this.NoDOSShell = 0; // bars are full screen
this.DOSShellBlink = 1; // bars are on the DOS Shell white lines
this.NoDOSShellPalette = 2;
// user choice decrunch type
this.DType = DType;
this.palette = new Array();
// base size of decruch bar
this.MaxBarHeight = MaxBarHeight;
// working canvas
this.mycanvas_temp = new canvas(640, 480)
// = 1 when all is done
this.finished = 0;
this.doDecrunch = function (dest) {
// working canvas sizes
var W = this.mycanvas_temp.contex.canvas.width;
var H = this.mycanvas_temp.contex.canvas.height;
// images sizes
var w1 = this.DOSshell.width;
var h1 = this.DOSshell.height;
// Before decrunch we only draw the DOS shell window
if (this.DecrunchVBLs < this.StartDecrunchAt) {
this.mycanvas_temp.contex.drawImage(this.DOSshell, 0, 0, w1, h1);
} else {
// We will parse y
var y = 0;
// While not parsed all height of working canvas
while (y <= H) {
// calculate color bar height
var barh = (1 + Math.random()) * this.MaxBarHeight;
// draws the bar
var mycolor;
if ((this.DType == this.NoDOSShellPalette) && (this.palette.length > 0)) {
mycolor = this.palette[Math.round(Math.random() * this.palette.length)];
} else {
mycolor = get_random_color();
}
this.mycanvas_temp.contex.fillStyle = mycolor;
this.mycanvas_temp.contex.fillRect(0, y, W, barh);
// next bar
y += barh;
}
// if DOS shell window is the only thing that must blink
if (this.DType == this.DOSShellBlink) {
// set destination-in canvas mode
this.mycanvas_temp.contex.globalCompositeOperation = 'destination-in';
// draw the DOS shell window
this.mycanvas_temp.contex.drawImage(this.DOSshell, 0, 0, w1, h1);
// back to normal mode
this.mycanvas_temp.contex.globalCompositeOperation = 'source-over';
}
}
// put destination canvas into no AA mode
dest.contex.ImageSmoothingEnabled = false;
dest.contex.webkitImageSmoothingEnabled = false;
dest.contex.mozImageSmoothingEnabled = false;
dest.contex.oImageSmoothingEnabled = false;
// Black Shell background color
dest.fill('#000000');
// calculate the destination scale
var scx = dest.contex.canvas.width / W;
var scy = dest.contex.canvas.height / H;
// draw that decrunch
this.mycanvas_temp.draw(dest, 0, 0, 1, 0, scx, scy);
// next frame please
this.DecrunchVBLs++;
// are we finished ?
if (this.DecrunchVBLs >= this.DecrunchMaxVBL) {
this.finished = 1;
}
};
return this;
};
lib.decrunch = decrunch;
if(typeof module!=='undefined'&& module.exports){module.exports=lib;}else{global.cdf=lib;}
})(this);