Coding horror experiment in HTML 5

Started by
20 comments, last by rip-off 10 years, 4 months ago

Added background image.

Added title.

TODO: game mechanics if I have the time.


<!DOCTYPE html>
<html>
<head>
    <title>Horror!</title>
    <style type="text/css">
        body {
            text-align:center;
            margin: 0;
            padding: 0;
			background-image:url('http://fc09.deviantart.net/fs70/f/2010/323/9/8/black_stone_by_rls0812-d335i0x.jpg');
        }
		<!-- I own the copyright to the background image, and it may be used for purpose of this project ~RLS0812 -->
    </style>
</head>
<body>
<br>
<div>
<canvas id="Title" width="800" height="35" style="border:4px solid #600000;">
<h1><b><center>Your browser is outdated. Use <a href="http://mozilla-firefox.todownload.com">FireFox</a> !</center></b></h1></canvas>
<script>
var Title = "Only Frankenstein Can Save The World !";
var c=document.getElementById("Title");
var ctx=c.getContext("2d");
ctx.rect(0,0,800,35);;
ctx.fillStyle="#000000";
ctx.fill();
var gradient=ctx.createLinearGradient(0,0,c.width,0);
gradient.addColorStop("0","#FF0000");
gradient.addColorStop("0.5","#FFFFFF");
gradient.addColorStop("1.0","#FF0000");
ctx.font="39px Verdana";
ctx.fillStyle=gradient;
ctx.fillText(Title,2,32);
</script>
</div>
<div>
    <canvas id="canvas" width="800" height="600" style="border:4px solid #600000;">
        Your browser does not support the canvas element
    </canvas>
	
</div>
<div id="hiddenStuff" style="display: none">
    <script>
        function makeTransparent(imageElement) {
            var canvas = document.createElement("canvas");
            canvas.width = imageElement.width;
            canvas.height = imageElement.height;
            document.getElementById("hiddenStuff").appendChild(canvas);
 
            var context = canvas.getContext("2d");
            context.drawImage(imageElement, 0, 0);
 
            var canvasImage = context.getImageData(0, 0, canvas.width, canvas.height); //IE10 error: IndexSizeError
            var imageData = canvasImage.data;
            for(var i = 0; i < imageData.length; i += 4) {
                if(imageData[i + 0] == 0 && imageData[i + 1] == 0 && imageData[i + 2] == 0) {
                    imageData[i + 3] = 0;
                }
            }
            canvasImage.data = imageData;
            context.putImageData(canvasImage, 0, 0);
 
            var newImage = new Image();
            newImage.src = canvas.toDataURL();
            return newImage;
        }
        
        function Particle(x, y, vx, vy, color, size, lifeTime) {
            this.x = x;
            this.y = y;
            this.vx = vx;
            this.vy = vy;
            this.color = color;
            this.size = size;
            this.lifeTime = lifeTime;
            
            this.Update = function(delta) {
                this.x += this.vx * delta;
                this.y += this.vy * delta;
                this.lifeTime -= delta;
            }
        }
        
        function CreateParticleExplosion(x, y, particles) {
            for(var i = 0; i < 100; ++i) {
                particles.push(new Particle(x, y, Math.random() - 0.5, Math.random() - 0.5, '#FF0000', 10, 5000));
            }
        }
        
        function Rect(left, top, right, bottom) {
            this.left = left;
            this.right = right;
            this.top = top;
            this.bottom = bottom;
        }
        
        function IntersectRect(r1, r2) {
            return !(r2.left > r1.right || 
                r2.right < r1.left || 
                r2.top > r1.bottom ||
                r2.bottom < r1.top);
        }
 
        window.onload = function () {
            var canvas = document.getElementById("canvas");
            if (canvas.getContext) {
                var canvasWidth = canvas.offsetWidth;
                var canvasHeight = canvas.offsetHeight;
                var context = canvas.getContext("2d");
                var lastTime = 0;
                var keys = new Object();
                var skipDelta = 0;
                var skipInterval = 4;
                var lightning = { current: 0, max: 0 };
                var speed = 0.5;
                var particles = [];
 
                context.fillStyle = "rgb(0, 0, 0)";
                context.fillRect(0, 0, canvasWidth, canvasHeight);
 
                var sprite = makeTransparent(document.getElementById("sprite"));
                var x = Math.random() * (canvasWidth - sprite.width);
                var y = Math.random() * (canvasHeight - sprite.height);
 
                var organIds = ['brain', 'heart', 'lungs', 'liver', 'kidney', 'stomache', 'intestines', 'ghost1', 'ghost2', 'ghost3'];
                var organs = [];
                var organImages = [];
 
                for (var i = 0 ; i < organIds.length ; ++i) {
                    var organImage = document.getElementById(organIds[i]);
                    organImages.push(makeTransparent(organImage));
                }
 
                for (var i = 0 ; i < organIds.length * 10; ++i) {
                    var organX = Math.random() * (canvasWidth - sprite.width);
                    var organY = Math.random() * (canvasHeight - sprite.height);
                    organs.push({ image: organImages[i % organIds.length], x: organX, y: organY, origX: organX, origY: organY });
                }
 
                function Draw() {
                    var LIGHTNING_WIDTH = 0.03;
                    if (Math.random() > 0.99 && lightning.current <= 0) {
                        lightning.max = 100 * (0.5 + Math.random());
                        lightning.current = lightning.max;
                        var LIGHTNING_NOT_TOO_CLOSE_TO_EDGE = LIGHTNING_WIDTH * 3;
                        lightning.position = LIGHTNING_NOT_TOO_CLOSE_TO_EDGE + ((1 - LIGHTNING_NOT_TOO_CLOSE_TO_EDGE) * Math.random());
                    }
 
                    context.fillStyle = '#000000';
                    if(lightning.current > 0) {
                        context.fillRect(0, 0, canvasWidth, canvasHeight);
 
                        var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);
                        var gradientLimit = 8;
                        var gradientMid = gradientLimit / 2;
                        for (var i = 0; i < 1 * gradientLimit; i++) {
                            var offSet = i;
                            if(i == 0 || i == (gradientLimit - 1)) {
                                offSet = (i == 0) ? 0 : 1;
                            } else {
                                offSet = lightning.position;
                                var difference = i - gradientMid;
                                offSet += difference * LIGHTNING_WIDTH;
                            }
 
                            if(false) {
                                var randomColor = Math.floor(Math.random() * 9999999);
                                var randomColorHexString = '#' + randomColor.toString(16);
                            }
                            var redAndGreen = (i == gradientMid) ? 0xff : 0x00;
                            var blue = (Math.abs(i - gradientMid) < 2) ? 0xff : 0x00;
                            var lightningAlpha = lightning.current / lightning.max;
                            var randomColorRGBAString = "rgba(" + redAndGreen + "," + redAndGreen + "," + blue + "," + lightningAlpha + ")";
 
                            var offSetLimited = Math.min(1, Math.max(0, offSet))
                            grad.addColorStop(offSetLimited, randomColorRGBAString /* randomColorHexString */);
                        }
 
                        context.fillStyle = grad;
                        lightning.current -= 1;
                    }
                    context.fillRect(0, 0, canvasWidth, canvasHeight);
                    context.fillStyle = '#FFFFFF';
 
                    for (var i = 0 ; i < organs.length ; ++i) {
                        var organ = organs[i];
                        context.drawImage(organ.image, organ.x, organ.y);
                    }
                
                    for(var i = 0; i < particles.length; ++i) {
                        var p = particles[i];
                        context.fillStyle = p.color;
                        context.fillRect(p.x, p.y, p.size, p.size);
                    }
 
                    context.drawImage(sprite, x, y);
                }
 
                function keyEvent(e) {
                    e = e || window.event;
                    if (e.type == 'keyup') {
                        keys.down = null;
                    } else {
                        keys.down = e;
                    }
                }
 
                function Update(delta, now) {
                    skipDelta = skipInterval * delta;
                    
                    for(var i = 0 ; i < organs.length ; ++i) {
                        var organ = organs[i];
                        if(IntersectRect(new Rect(x, y, x + sprite.width, y + sprite.height),
                            new Rect(organ.x, organ.y, organ.x + sprite.width, organ.y + sprite.height))) {
                            organs.splice(i, 1);
                            CreateParticleExplosion(x, y, particles);
                        }
                    }
                
                    for(var i = 0; i < particles.length; ++i) {
                        if(particles[i].lifeTime <= 0) {
                            particles.splice(i, 1);
                        } else {
                            particles[i].Update(delta);
                        }
                    }
 
                    for (var i = 0 ; i < organs.length ; ++i) {
                        var organ = organs[i];
                        organ.x = organ.origX + Math.cos(now/((i%5)*100 + 500) + i) * (i % 20);
                        organ.y = organ.origY + Math.sin(now/((i%5)*100 + 500) + i) * (i % 20);
                    }
 
                    if(lightning.current > 0) {
                        for (var i = 0 ; i < organs.length ; ++i) {
                            var organ = organs[i];
                            organ.x += Math.random() * lightning.current/4;
                            organ.y += Math.random() * lightning.current/4;
                        }
                    }
 
                    if (e = keys.down) {
                        if (e.keyCode == '87') {
                            y -= delta * speed;
                        } else if (e.keyCode == '83') {
                            y += delta * speed;
                        } else if (e.keyCode == '65') {
                            x -= delta * speed;
                        } else if (e.keyCode == '68') {
                            x += delta * speed;
                        } else if (e.keyCode == '84') {
                            y -= skipDelta;
                        } else if (e.keyCode == '71') {
                            y += skipDelta;
                        } else if (e.keyCode == '70') {
                            x -= skipDelta;
                        } else if (e.keyCode == '72') {
                            x += skipDelta;
                        }
                        
                        if(x < 0) {
                            x = 0;
                        } else if(x > (canvasWidth - sprite.width)) {
                            x = canvasWidth - sprite.width;
                        }
                        
                        if(y < 0) {
                            y = 0;
                        } else if(y > (canvasHeight - sprite.height)) {
                            y = canvasHeight - sprite.height;
                        }
                    }
                }
 
                var fps = 60;
                var intervalId = setInterval(function () {
                    var now = Date.now();
                    if(lastTime === 0) {
                        lastTime = now;
                    }
                    var delta = now - lastTime;
                    lastTime = now;
                    Update(delta, now);
                    Draw();
                }, 1000 / fps);
 
                document.onkeydown = keyEvent;
                document.onkeyup = keyEvent;
            }
        }
    </script>
    <img id="sprite" src=""/>
    <img id="brain" src=""/>
    <img id="heart" src=""/>
    <img id="lungs" src=""/>
    <img id="liver" src=""/>
    <img id="kidney" src=""/>
    <img id="stomache" src=""/>
    <img id="intestines" src=""/>
    //Credit for sprites goes to George Williams
    //http://gmc.yoyogames.com/index.php?showtopic=302110
    <img id="ghost1" src="" />
    <img id="ghost2" src="" />
    <img id="ghost3" src="" />
</div>
<br><br><br>
</body>
</html>

I cannot remember the books I've read any more than the meals I have eaten; even so, they have made me.

~ Ralph Waldo Emerson

Advertisement

Added some gameplay. Now Frankenstein has to collect all the organs without touching the ghosts.

Also made the blood fx more next gen.

qurc.png


<!DOCTYPE html>
<html>
<head>
    <title>Horror!</title>
    <style type="text/css">
        body {
            text-align:center;
            margin: 0;
            padding: 0;
            background-image:url('http://fc09.deviantart.net/fs70/f/2010/323/9/8/black_stone_by_rls0812-d335i0x.jpg');
        }
        <!-- I own the copyright to the background image, and it may be used for purpose of this project ~RLS0812 -->
    </style>
</head>
<body>
<br>
<div>
<canvas id="Title" width="800" height="35" style="border:4px solid #600000;">
<h1><b><center>Your browser is outdated. Use <a href="http://mozilla-firefox.todownload.com">FireFox</a> !</center></b></h1></canvas>
<script>
var Title = "Only Frankenstein Can Save The World !";
var c=document.getElementById("Title");
var ctx=c.getContext("2d");
ctx.rect(0,0,800,35);;
ctx.fillStyle="#000000";
ctx.fill();
var gradient=ctx.createLinearGradient(0,0,c.width,0);
gradient.addColorStop("0","#FF0000");
gradient.addColorStop("0.5","#FFFFFF");
gradient.addColorStop("1.0","#FF0000");
ctx.font="39px Verdana";
ctx.fillStyle=gradient;
ctx.fillText(Title,2,32);
</script>
</div>
<div>
    <canvas id="canvas" width="800" height="600" style="border:4px solid #600000;">
        Your browser does not support the canvas element
    </canvas>
    
</div>
<div id="hiddenStuff" style="display: none">
    <script>
        function makeTransparent(imageElement) {
            var canvas = document.createElement("canvas");
            canvas.width = imageElement.width;
            canvas.height = imageElement.height;
            document.getElementById("hiddenStuff").appendChild(canvas);
 
            var context = canvas.getContext("2d");
            context.drawImage(imageElement, 0, 0);
 
            var canvasImage = context.getImageData(0, 0, canvas.width, canvas.height); //IE10 error: IndexSizeError
            var imageData = canvasImage.data;
            for(var i = 0; i < imageData.length; i += 4) {
                if(imageData[i + 0] == 0 && imageData[i + 1] == 0 && imageData[i + 2] == 0) {
                    imageData[i + 3] = 0;
                }
            }
            canvasImage.data = imageData;
            context.putImageData(canvasImage, 0, 0);
 
            var newImage = new Image();
            newImage.src = canvas.toDataURL();
            return newImage;
        }
        
        function Particle(x, y, vx, vy, color, size, lifeTime) {
            this.x = x;
            this.y = y;
            this.vx = vx;
            this.vy = vy;
            this.color = color;
            this.size = size;
            this.lifeTime = lifeTime;
            
            this.Update = function(delta) {
                this.x += this.vx * delta;
                this.y += this.vy * delta;
                this.lifeTime -= delta;
            }
        }
        
        function CreateParticleExplosion(x, y, particles) {
            for(var i = 0; i < 50; ++i) {
                var red = Math.floor(Math.random() * 16).toString(16);
                particles.push(new Particle(x, y, Math.random() - 0.5, Math.random() - 0.5, '#' + red + 'F0000', 10 * Math.random(), 5000));
            }
        }
        
        function Rect(left, top, right, bottom) {
            this.left = left;
            this.right = right;
            this.top = top;
            this.bottom = bottom;
        }
        
        function IntersectRect(r1, r2) {
            return !(r2.left > r1.right || 
                r2.right < r1.left || 
                r2.top > r1.bottom ||
                r2.bottom < r1.top);
        }
        
        function fillRoundedRect(x, y, w, h, r) {
            /* code from http://gmigdos.wordpress.com/2010/05/20/javascript-draw-a-rounded-rectangle-on-an-html-5-canvas/ */
            this.beginPath();
            this.moveTo(x+r, y);
            this.lineTo(x+w-r, y);
            this.quadraticCurveTo(x+w, y, x+w, y+r);
            this.lineTo(x+w, y+h-r);
            this.quadraticCurveTo(x+w, y+h, x+w-r, y+h);
            this.lineTo(x+r, y+h);
            this.quadraticCurveTo(x, y+h, x, y+h-r);
            this.lineTo(x, y+r);
            this.quadraticCurveTo(x, y, x+r, y);
            this.fill();       
        }
 
        window.onload = function () {
            CanvasRenderingContext2D.prototype.fillRoundedRect = fillRoundedRect;
            
            var canvas = document.getElementById("canvas");
            if (canvas.getContext) {
                var canvasWidth = canvas.offsetWidth;
                var canvasHeight = canvas.offsetHeight;
                var context = canvas.getContext("2d");
                var lastTime = 0;
                var keys = new Object();
                var skipDelta = 0;
                var skipInterval = 4;
                var lightning = { current: 0, max: 0 };
                var speed = 0.5;
                var particles = [];
                var lives = 5;
 
                context.fillStyle = "rgb(0, 0, 0)";
                context.fillRect(0, 0, canvasWidth, canvasHeight);
 
                var sprite = makeTransparent(document.getElementById("sprite"));
                var x = Math.random() * (canvasWidth - sprite.width);
                var y = Math.random() * (canvasHeight - sprite.height);
 
                var organIds = ['brain', 'heart', 'lungs', 'liver', 'kidney', 'stomache', 'intestines', 'ghost1', 'ghost2', 'ghost3'];
                var organs = [];
                var organImages = [];
 
                for (var i = 0 ; i < organIds.length ; ++i) {
                    var organImage = document.getElementById(organIds[i]);
                    organImages.push(makeTransparent(organImage));
                }
 
                for (var i = 0 ; i < organIds.length * 10; ++i) {
                    var organX = Math.random() * (canvasWidth - sprite.width);
                    var organY = Math.random() * (canvasHeight - sprite.height);
                    organs.push({ organId: i % organIds.length, image: organImages[i % organIds.length], x: organX, y: organY, origX: organX, origY: organY });
                }
 
                function Draw() {
                    var LIGHTNING_WIDTH = 0.03;
                    if (Math.random() > 0.99 && lightning.current <= 0) {
                        lightning.max = 100 * (0.5 + Math.random());
                        lightning.current = lightning.max;
                        var LIGHTNING_NOT_TOO_CLOSE_TO_EDGE = LIGHTNING_WIDTH * 3;
                        lightning.position = LIGHTNING_NOT_TOO_CLOSE_TO_EDGE + ((1 - LIGHTNING_NOT_TOO_CLOSE_TO_EDGE) * Math.random());
                    }
 
                    context.fillStyle = '#000000';
                    if(lightning.current > 0) {
                        context.fillRect(0, 0, canvasWidth, canvasHeight);
 
                        var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);
                        var gradientLimit = 8;
                        var gradientMid = gradientLimit / 2;
                        for (var i = 0; i < 1 * gradientLimit; i++) {
                            var offSet = i;
                            if(i == 0 || i == (gradientLimit - 1)) {
                                offSet = (i == 0) ? 0 : 1;
                            } else {
                                offSet = lightning.position;
                                var difference = i - gradientMid;
                                offSet += difference * LIGHTNING_WIDTH;
                            }
 
                            if(false) {
                                var randomColor = Math.floor(Math.random() * 9999999);
                                var randomColorHexString = '#' + randomColor.toString(16);
                            }
                            var redAndGreen = (i == gradientMid) ? 0xff : 0x00;
                            var blue = (Math.abs(i - gradientMid) < 2) ? 0xff : 0x00;
                            var lightningAlpha = lightning.current / lightning.max;
                            var randomColorRGBAString = "rgba(" + redAndGreen + "," + redAndGreen + "," + blue + "," + lightningAlpha + ")";
 
                            var offSetLimited = Math.min(1, Math.max(0, offSet))
                            grad.addColorStop(offSetLimited, randomColorRGBAString /* randomColorHexString */);
                        }
 
                        context.fillStyle = grad;
                        lightning.current -= 1;
                    }
                    context.fillRect(0, 0, canvasWidth, canvasHeight);
                    context.fillStyle = '#FFFFFF';
 
                    for (var i = 0 ; i < organs.length ; ++i) {
                        var organ = organs[i];
                        context.drawImage(organ.image, organ.x, organ.y);
                    }
                
                    for(var i = 0; i < particles.length; ++i) {
                        var p = particles[i];
                        context.fillStyle = p.color;
                        context.fillRect(p.x, p.y, p.size, p.size);
                    }
 
                    context.drawImage(sprite, x, y);
                    
                    context.fillStyle = '#333';
                    context.fillRoundedRect(30, 520, 170, 50, 20);
                    
                    for(var i = 0; i < lives; ++i) {
                        context.drawImage(sprite, 38 + i * 30, 528);
                    }
                }
 
                function keyEvent(e) {
                    e = e || window.event;
                    if (e.type == 'keyup') {
                        keys.down = null;
                    } else {
                        keys.down = e;
                    }
                }
                
                function LoseGame() {
                    for(var i = 0 ; i < organs.length ; ++i) {
                        var organ = organs[i];
                        CreateParticleExplosion(organ.x, organ.y, particles);
                    }
                    
                    organs = [];
                }
 
                function Update(delta, now) {
                    skipDelta = skipInterval * delta;
                    
                    for(var i = 0 ; i < organs.length ; ++i) {
                        var organ = organs[i];
                        if(IntersectRect(new Rect(x, y, x + sprite.width, y + sprite.height),
                            new Rect(organ.x, organ.y, organ.x + sprite.width, organ.y + sprite.height))) {
                            organs.splice(i, 1);
                            CreateParticleExplosion(x, y, particles);
                            if(organ.organId > 6) {
                                --lives;
                                if(lives == 0) {
                                    LoseGame();
                                    break;
                                }
                            }
                        }
                    }
                
                    for(var i = 0; i < particles.length; ++i) {
                        if(particles[i].lifeTime <= 0) {
                            particles.splice(i, 1);
                        } else {
                            particles[i].Update(delta);
                        }
                    }
 
                    for (var i = 0 ; i < organs.length ; ++i) {
                        var organ = organs[i];
                        organ.x = organ.origX + Math.cos(now/((i%5)*100 + 500) + i) * (i % 20);
                        organ.y = organ.origY + Math.sin(now/((i%5)*100 + 500) + i) * (i % 20);
                    }
 
                    if(lightning.current > 0) {
                        for (var i = 0 ; i < organs.length ; ++i) {
                            var organ = organs[i];
                            organ.x += Math.random() * lightning.current/4;
                            organ.y += Math.random() * lightning.current/4;
                        }
                    }
 
                    if (e = keys.down) {
                        if (e.keyCode == '87') {
                            y -= delta * speed;
                        } else if (e.keyCode == '83') {
                            y += delta * speed;
                        } else if (e.keyCode == '65') {
                            x -= delta * speed;
                        } else if (e.keyCode == '68') {
                            x += delta * speed;
                        } else if (e.keyCode == '84') {
                            y -= skipDelta;
                        } else if (e.keyCode == '71') {
                            y += skipDelta;
                        } else if (e.keyCode == '70') {
                            x -= skipDelta;
                        } else if (e.keyCode == '72') {
                            x += skipDelta;
                        }
                        
                        if(x < 0) {
                            x = 0;
                        } else if(x > (canvasWidth - sprite.width)) {
                            x = canvasWidth - sprite.width;
                        }
                        
                        if(y < 0) {
                            y = 0;
                        } else if(y > (canvasHeight - sprite.height)) {
                            y = canvasHeight - sprite.height;
                        }
                    }
                }
 
                var fps = 60;
                var intervalId = setInterval(function () {
                    var now = Date.now();
                    if(lastTime === 0) {
                        lastTime = now;
                    }
                    var delta = now - lastTime;
                    lastTime = now;
                    Update(delta, now);
                    Draw();
                }, 1000 / fps);
 
                document.onkeydown = keyEvent;
                document.onkeyup = keyEvent;
            }
        }
    </script>
    <img id="sprite" src=""/>
    <img id="brain" src=""/>
    <img id="heart" src=""/>
    <img id="lungs" src=""/>
    <img id="liver" src=""/>
    <img id="kidney" src=""/>
    <img id="stomache" src=""/>
    <img id="intestines" src=""/>
    //Credit for sprites goes to George Williams
    //http://gmc.yoyogames.com/index.php?showtopic=302110
    <img id="ghost1" src="" />
    <img id="ghost2" src="" />
    <img id="ghost3" src="" />
</div>
<br><br><br>
</body>
</html>

Thanks everyone, I'm closing the experiment. As noted after the jump, all this really means is that I'm unpinning the topics, by all means continue to contribute!

This topic is closed to new replies.

Advertisement