CodePen

HTML

            
              <div>
    <canvas id="canvas"></canvas>
</div>
            
          
!
via HTML Inspector

CSS

            
              @import url(http://fonts.googleapis.com/css?family=Press+Start+2P);

body {
  margin : 0;
  font-family:'Press Start 2P';
  background: #000;
  width:100%;
}
div{width:640px;margin: 100px auto;}
canvas {
  font-family:'Press Start 2P';
}
            
          
!
? ?
? ?
Must be a valid URL.
+ add another resource
via CSS Lint

JS

            
              /*
OMG cors how I hate thee. Images are loaded with dataurls.. and are quite long
*/
(function () {
      var requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame || function (callback) {
              window.setTimeout(callback, 1000 / 60);
          };
      window.requestAnimationFrame = requestAnimationFrame;
  })();



    var canvas = document.getElementById("canvas"),
        ctx = canvas.getContext("2d"),
        width = 640,
        height = 480,
        c64p = [
            "#000",
            "#FFF",
            "#903040",
            "#93ffff",
            "#702bff",
            "#40b710",
            "#2000bf",
            "#e0e060",
            "#b05030",
            "#803000",
            "#ff7b9e",
            "#404040",
            "#909090",
            "#90FF90",
            "#3060FF",
            "#C0C0C0"],
        c64pRGB = [
            {r: 0, g : 0, b : 0},
            {r: 255, g : 255, b : 255},
            {r: 144, g : 48, b : 64},
            {r: 147, g : 255, b : 255},
            {r: 112, g : 43, b : 255},
            {r: 64, g : 183, b : 16},
            {r: 32, g : 0, b : 191},
            {r: 224, g : 224, b : 96},
            {r: 176, g : 80, b : 48},
            {r: 128, g : 48, b : 0},
            {r: 255, g : 123, b : 158},
            {r: 64, g : 64, b : 64},
            {r: 144, g : 144, b : 144},
            {r: 144, g : 255, b : 144},
            {r: 48, g : 96, b : 255},
            {r: 192, g : 192, b : 192}
        ],
        audio = new Audio(),
        cur = {
            x: 40,
            y: 110,
            on: true,
            lastBlink: new Date().getTime(),
            waitTime: 400,
            actions: [{
                time: 2000, text: "L"
            }, {
                time: 180, text: "O"
            }, {
                time: 220, text: "A"
            }, {
                time: 120, text: "D"
            }, {
                time: 120, text: " "
            }, {
                time: 850, text: '"'
            }, {
                time: 110, text: "*"
            }, {
                time: 580, text: '"'
            }, {
                time: 370, text: ","
            }, {
                time: 300, text: "8"
            }, {
                time: 350, text: ","
            }, {
                time: 310, text: "1"
            }, {
                time: 100, ret: true
            }, {
                time: 100, ret: true
            }, {
                time: 500, text: "SEARCHING FOR *"
            },
            { time: 1000, ret: true },
            { time: 0, text: "LOADING" },
            { time: 2000, ret: true },
            { time: 0, text: "READY" },
            { time: 0, ret: true },
            { time: 500, text: "R" },
            { time: 500, text: "U" },
            { time: 450, text: "N" },
            { time: 300, ret: true }
            ],
            curAction: 0,
            lastAction: new Date().getTime(),
            render: function () {
                if (this.curAction < this.actions.length) {
                    if (new Date().getTime() > this.lastAction + this.actions[this.curAction].time) {
                        var action = this.actions[this.curAction];
                        this.lastAction = new Date().getTime();

                        // remove the cursor
                        ctx.fillStyle = c64p[6];
                        ctx.fillRect(this.x, this.y, 12, 14);
                        if (!action.ret) {
                            ctx.fillStyle = c64p[14];
                            ctx.fillText(action.text, this.x, this.y + 14);

                            this.x += action.text.length * 12;
                        } else {
                            this.x = 40;
                            this.y += 14;
                        }

                        this.curAction++;
                    }
                }

                // blink
                if (new Date().getTime() > this.lastBlink + this.waitTime) {
                    this.lastBlink = new Date().getTime();
                    if (this.on) {
                        ctx.fillStyle = c64p[14];
                        ctx.fillRect(this.x, this.y, 12, 14);
                        this.on = false;
                    } else {
                        ctx.fillStyle = c64p[6];
                        ctx.fillRect(this.x, this.y, 12, 14);
                        this.on = true;
                    }
                }
            }
        },
        titleImage = new Image(),
        titleCan = document.createElement("canvas"),
        titleCtx = titleCan.getContext("2d"),
        staticText = new Image(),
        staticCan = document.createElement("canvas"),
        staticCtx = staticCan.getContext("2d"),
        scrollText = new Image(),
        scrollCan = document.createElement("canvas"),
        scrollCtx = scrollCan.getContext("2d"),
        scrollTemp = document.createElement("canvas"),
        scrollTCtx = scrollTemp.getContext("2d"),
        dTitle = {
            x : width,
            y : 10
        },
        startDemo = function () {
            cur.render();
            if (cur.curAction == cur.actions.length) {
                demoStep++;
                demoStart = new Date().getTime();
            }
        },
        loading = function () {
            bars = 50;
            while (bars--) {
                ctx.fillStyle = c64p[parseInt(Math.random() * 16)];
                ctx.fillRect(0, (width / 50 * bars), width, Math.random() * width / 10);
            }
            ctx.fillStyle = c64p[6];
            ctx.fillRect(40, 40, width - 80, height - 80);
        },
        intro = {
            step : 0,
            flash : 0,
            showText : false,
            staticGrad : [7,8,9,10,4,6,14,3,13,5],
            staticTime : new Date().getTime(),
            scrollX : -canvas.width*2,
            ang : 0,
            pix : null,
            newImageData : null,
            npix : null,
            titleFlash : function(){
                var imageData = titleCtx.getImageData(0,0,titleCan.width,titleCan.height),
                    pix = imageData.data;

                for (var i = 0, n = pix.length; i <n; i += 4) {
                    pix[i] = Math.min(pix[i] + this.flash, 255);
                    pix[i+1] = Math.min(pix[i] + this.flash, 255);
                    pix[i+2] = Math.min(pix[i] + this.flash, 255);
                }
                titleCtx.putImageData(imageData, 0, 0);
            },
            staticUpdate : function(){
                this.imageData = staticCtx.getImageData(0,0,staticCan.width,staticCan.height),
                this.pix = this.imageData.data;

                for(var x = 0; x < staticCan.width; x++) {
                    for(var y = 0; y < staticCan.height; y++) {
                        var pData = (x + y * staticCan.width) * 4,
                            rounded = Math.round(y/10)*10,
                            gradCol = c64pRGB[this.staticGrad[Math.abs(y - rounded)]];

                       this. pix[pData] = gradCol.r;
                    this.pix[pData+1] = gradCol.g;
                       this.pix[pData+2] = gradCol.b;
                    }
                }

                // update the gradient
                if(new Date().getTime() > this.staticTime + 50){
                    this.staticTime = new Date().getTime();
                    this.staticGrad.push(this.staticGrad.shift());
                }

                staticCtx.putImageData(this.imageData, 0, 0);
            },
            scrollUpdate : function(){
                this.scrollX+=4;
                if(this.scrollX >= scrollCan.width){
                    this.scrollX = -canvas.width;
                }
                this.pix = scrollCtx.getImageData(this.scrollX,0,scrollTemp.width,scrollTemp.height).data;

                this.newImageData = scrollTCtx.createImageData(scrollTemp.width,scrollTemp.height);
                this.npix = this.newImageData.data;

                for(var x = 0; x < scrollTemp.width; x++) {
                    this.ang+=0.01;
                    for(var y = 0; y < scrollTemp.height; y++) {
                        var pData = (x + y * scrollTemp.width) * 4,
                            pData2 = (x + (y-Math.round(Math.sin(this.ang)*20)) * scrollTemp.width) * 4;

                        this.npix[pData] = this.pix[pData2];
                        this.npix[pData+1] = this.pix[pData2+1];
                        this.npix[pData+2] = this.pix[pData2+2];
                        this.npix[pData+3] = this.pix[pData2+3];
                    }
                }

                scrollTCtx.putImageData(this.newImageData, 0, 0);

            },
            blood : [],
            addBlood : function(){
                this.blood.push({
                    x : 550+Math.random()*50, 
                    y : 50 + Math.random()*10, 
                    speed : 6+Math.random(),
                    drip : false,
                    ang : 0
                });
            },
            bloodDrip : function(){
                ctx.fillStyle = c64p[2];
                for(var b = 0; b < this.blood.length; b++){

                    if(this.blood[b].drip){
                        this.blood[b].y += this.blood[b].speed;
                        
                        if(this.blood[b].y > canvas.height){
                            this.blood[b].y = 50 + Math.random()*10;
                            this.blood[b].x = 550+Math.random()*50;
                            this.blood[b].drip = false;

                            if(this.blood.length < 8){
                                this.addBlood();
                            }
                        }

                        ctx.fillRect(this.blood[b].x, this.blood[b].y, 4, 6);
                    }else{
                        this.blood[b].ang+=0.05;
                        var stretch = Math.round(Math.sin(this.blood[b].ang)*30);

                        if(stretch > 25){
                             this.blood[b].drip = true;
                             this.blood[b].ang = 0;
                        }

                        ctx.fillRect(this.blood[b].x, this.blood[b].y, 4, stretch);
                    }
                }
            },
            update : function () {
                ctx.fillStyle = c64p[0];
                ctx.fillRect(0, 0, width, height);

                switch(this.step){
                    case 0:
                        dTitle.x -=3;
                        if(dTitle.x < 10){
                            dTitle.x = 10;
                            this.step++;
                        }
                    break;
                    case 1:
                        this.titleFlash();
                        this.flash +=30;
                        if(this.flash>=255){
                            this.flash = 0;
                            this.step++;
                        }
                    break;
                    case 2:
                        this.titleFlash();
                        this.flash -=30;
                        if(this.flash<=-255){
                            this.step++;
                            titleCtx.drawImage(titleImage,0,0);
                            this.showText = true;
                            // init 2 drops
                            this.addBlood();
                            this.addBlood();
                        }
                    break;
                }

                if(this.showText){
                    this.staticUpdate();
                    this.scrollUpdate();
                    ctx.drawImage(staticCan,188,150);
                    ctx.drawImage(scrollTemp,0,350);
                    this.bloodDrip();
                }
                ctx.drawImage(titleCan, dTitle.x,dTitle.y);
            }
        },
        demoStep = 0,
        demoStart = new Date().getTime(),
        demoSteps = [{
            callBack: function () {
                startDemo();
            },
            totalTime: 0
        }, {
            callBack: function () {
                loading();
            },
            totalTime: 2000
        }, {
            callBack: function () {
                audio.play();
                demoStep++;
            },
            totalTime: 0
        }, {
            callBack: function () {
                intro.update();
            },
            totalTime: 0
        }],
        demoController = function () {
            var demo = demoSteps[demoStep];

            if (demo.totalTime > 0) {
                if (new Date().getTime() > demoStart + demo.totalTime) {
                    demoStart = new Date().getTime();
                    demoStep++;
                }
            }

            demo.callBack();
            requestAnimationFrame(function () {
                demoController();
            });
        };

        setTimeout(function () {
            canvas.width = width;
            canvas.height = height;

            audio.src = "http://www.somethinghitme.com/projects/aud/the_wrong_funky.ogg";
            audio.src = "http://www.somethinghitme.com/projects/aud/the_wrong_funky.mp3";
            audio.preload = true;

            ctx.fillStyle = c64p[14];
            ctx.fillRect(0, 0, width, height);

            ctx.fillStyle = c64p[6];
            ctx.fillRect(40, 40, width - 80, height - 80);

            ctx.textAlign = "center";
            ctx.fillStyle = c64p[14];
            ctx.font = "12px 'Press Start 2P'";
            ctx.fillText("**** COMMODORE 64 BASIC V2 ****", width / 2, 60);
            ctx.fillText("64k RAM SYSTEM  38911 BASIC BYTES FREE", width / 2, 80);
            ctx.textAlign = "left";
            ctx.fillText("READY.", 42, 110);

            titleImage.src = "";
            titleImage.addEventListener("load", function(){
                titleCan.width = 606;
                titleCan.height = 87;

                titleCtx.drawImage(titleImage,0,0);
            });

            staticText.src = "";
            staticText.addEventListener("load", function(){
                staticCan.width = 265;
                staticCan.height = 129;

                staticCtx.drawImage(staticText,0,0);
            });

            scrollText.src = "";
            scrollText.addEventListener("load", function(){
                scrollCan.width = 13474;
                scrollCan.height = 60;

                scrollCtx.drawImage(scrollText,0,20);

                scrollTemp.width = canvas.width;
                scrollTemp.height = 60;
                demoController();
            });

        }, 200);
            
          
!
Must be a valid URL.
+ add another resource
via JS Hint
Loading ..................