Jump to content

  • Log In with Google      Sign In   
  • Create Account

staunsholm

Member Since 25 Jul 2013
Offline Last Active Apr 06 2014 06:03 AM

Posts I've Made

In Topic: Coding horror experiment in HTML 5

03 November 2013 - 03:23 PM

Added some movement, and heavy shaking when lightning strikes.

<!DOCTYPE html>
<html>
<head>
    <title>Horror!</title>
</head>
<body>
<div>
    <canvas id="canvas" width="800" height="600">
        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);
            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;
        }

        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 delta = 0;
                var skipDelta = 0;
                var skipInterval = 4;
                var lightning = { current: 0, max: 0 };

                context.fillStyle = "rgb(0, 0, 0)";
                context.fillRect(0, 0, canvasWidth, canvasHeight);

                var sprite = 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'];
                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);
                    }

                    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() {
                    var now = Date.now();
                    if (lastTime === 0) {
                        lastTime = now;
                    }
                    delta = now - lastTime;
                    skipDelta = skipInterval * delta;
                    lastTime = now;

                    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;
                        } else if (e.keyCode == '83') {
                            y += delta;
                        } else if (e.keyCode == '65') {
                            x -= delta;
                        } else if (e.keyCode == '68') {
                            x += delta;
                        } 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;
                        }
                    }
                }

                var fps = 60;
                var intervalId = setInterval(function () {
                    Update();
                    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=""/>
</div>
</body>
</html>

(no screen shot, it looks the same)

 

Mkkl.


In Topic: PUTT People's Choice Award and Comments

03 November 2013 - 09:08 AM

Not really easy to pull mine from github, since you need to setup a server to play it. Here's an online version:

 

http://test.staunsholm.dk/icecube/

 

(yes, needs webgl - but should work in all latest browserversions)

 

Mkkl.

 

PS! No, it's not finished :-)


In Topic: Power Up Table Tennis Contest

24 October 2013 - 03:24 PM

Sign me up! Actually looks like I will be getting something done...

 

Mkkl.


In Topic: PUTT Updates and Finals Thread

18 October 2013 - 05:33 PM

Had fun this evening:

 

http://test.staunsholm.dk/icecube/

 

Attached File  Screen Shot 2013-10-19 at 01.25.15.png   1.13MB   3 downloads

Attached File  Screen Shot 2013-10-19 at 01.27.25.png   624.41KB   2 downloads

 

Now, all I need is to turn it into something that I'd actually call a game :-)

 

Mkkl.

 

PS! don't worry: credits for music photo, music and sound will be added.

PPS! Code is here, if you want to steal something: https://github.com/staunsholm/ice-cube


PARTNERS