Jump to content

  • Log In with Google      Sign In   
  • Create Account

Coding horror experiment in HTML 5

  • You cannot reply to this topic
21 replies to this topic

#1 rip-off   Moderators   -  Reputation: 8223

Like
6Likes
Like

Posted 31 October 2013 - 05:34 PM

Welcome to the great GD.net collaborative coding horror experiment in HTML 5!
  • For an overview of what this is about, please read this thread.
  • The rules are here
In the spirit of the season, the theme for this game is "only Frankenstein can save the world"

This is the initial code. Please forgive any mistakes, I am still a relative beginner to HTML 5:
<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 style="display: none">
			<script>
				window.onload = function() {
					var canvas = document.getElementById("canvas");
					if(canvas.getContext) {
						var canvasWidth = canvas.offsetWidth;
						var canvasHeight = canvas.offsetHeight;
						var context = canvas.getContext("2d");
						
						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);
						context.drawImage(sprite, x, y);
					}
				}
			</script>
			<img id="sprite" src=""/>
		</div>
	</body>
</html>


Sponsor:

#2 froop   Members   -  Reputation: 636

Like
3Likes
Like

Posted 31 October 2013 - 08:15 PM

Adding some WSAD controls

<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 style="display: none">
			<script>
				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;
						
						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);
						
						function Draw() {
							context.drawImage(sprite, x, y);
						}
						
						function keyDown(e) {
							e = e || window.event;

							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;
							}
						}
						
						function Update() {
							var now = Date.now();
							if(lastTime === 0) {
								lastTime = now;
							}
							delta = now - lastTime;
							lastTime = now;
						}
						
						var fps = 60;
						var intervalId = setInterval(function() {
							Update();
							Draw();
						}, 1000 / fps);
					
						document.onkeydown = keyDown;
					}
				}
			</script>
			<img id="sprite" src=""/>
		</div>
	</body>
</html>


#3 GnollAF   Members   -  Reputation: 190

Like
4Likes
Like

Posted 31 October 2013 - 09:11 PM

<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 style="display: none">
			<script>
				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;
						
						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);
						
						function Draw() {
							if (Math.random() > 0.9)
							{
								var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

								for (var i = 0; i < 2; i++)
									grad.addColorStop(i, "#" + Math.floor(Math.random()*9999999).toString(16));
								context.fillStyle = grad;
							}
							context.fillRect(0, 0, canvasWidth, canvasHeight);
							context.drawImage(sprite, x, y);
						}
						
						function keyDown(e) {
							e = e || window.event;

							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;
							}
						}
						
						function Update() {
							var now = Date.now();
							if(lastTime === 0) {
								lastTime = now;
							}
							delta = now - lastTime;
							lastTime = now;
						}
						
						var fps = 60;
						var intervalId = setInterval(function() {
							Update();
							Draw();
						}, 1000 / fps);
					
						document.onkeydown = keyDown;
					}
				}
			</script>
			<img id="sprite" src=""/>
		</div>
	</body>
</html>


#4 Dragonsoulj   Crossbones+   -  Reputation: 2111

Like
2Likes
Like

Posted 31 October 2013 - 10:41 PM

Reversed the WASD to normal directions:

<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 style="display: none">
            <script>
                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;
                        
                        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);
                        
                        function Draw() {
                            if (Math.random() > 0.9)
                            {
                                var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

                                for (var i = 0; i < 2; i++)
                                    grad.addColorStop(i, "#" + Math.floor(Math.random()*9999999).toString(16));
                                context.fillStyle = grad;
                            }
                            context.fillRect(0, 0, canvasWidth, canvasHeight);
                            context.drawImage(sprite, x, y);
                        }
                        
                        function keyDown(e) {
                            e = e || window.event;

                            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;
                            }
                        }
                        
                        function Update() {
                            var now = Date.now();
                            if(lastTime === 0) {
                                lastTime = now;
                            }
                            delta = now - lastTime;
                            lastTime = now;
                        }
                        
                        var fps = 60;
                        var intervalId = setInterval(function() {
                            Update();
                            Draw();
                        }, 1000 / fps);
                    
                        document.onkeydown = keyDown;
                    }
                }
            </script>
            <img id="sprite" src=""/>
        </div>
    </body>
</html>


#5 Alpha_ProgDes   Crossbones+   -  Reputation: 4688

Like
2Likes
Like

Posted 01 November 2013 - 12:13 AM

<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 style="display: none">
            <script>
                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;
                        
                        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);
                        
                        function Draw() {
                            if (Math.random() > 0.9)
                            {
                                var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

                                for (var i = 0; i < 2; i++)
                                    grad.addColorStop(i, "#" + Math.floor(Math.random()*9999999).toString(16));  //syntax error in IE10
                                context.fillStyle = grad;
                            }
                            context.fillRect(0, 0, canvasWidth, canvasHeight);
                            context.drawImage(sprite, x, y);
                        }
                        
                        function keyDown(e) {
                            e = e || window.event;

                            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;
                            }
                        }
                        
                        function Update() {
                            var now = Date.now();
                            if(lastTime === 0) {
                                lastTime = now;
                            }
                            delta = now - lastTime;
                            lastTime = now;
                        }
                        
                        var fps = 60;
                        var intervalId = setInterval(function() {
                            Update();
                            Draw();
                        }, 1000 / fps);
                    
                        document.onkeydown = keyDown;
                    }
                }
            </script>
            <img id="sprite" src=""/>
        </div>
    </body>
</html>

Beginner in Game Development? Read here.
 
Super Mario Bros clone tutorial written in XNA 4.0 [MonoGame, ANX, and MonoXNA] by Scott Haley
 
If you have found any of the posts helpful, please show your appreciation by clicking the up arrow on those posts Posted Image
 
Spoiler

#6 rip-off   Moderators   -  Reputation: 8223

Like
1Likes
Like

Posted 01 November 2013 - 05:38 PM

Don't forget to include a brief summary of your changes. Also, the C++ guys have taken to posting screenshots, which is nice.

#7 Alpha_ProgDes   Crossbones+   -  Reputation: 4688

Like
1Likes
Like

Posted 02 November 2013 - 12:13 PM

Added T F G H movement, which allows Frankenstein to jump by x * delta.
 

<!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 style="display: none">
            <script>
                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;

                        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);

                        function Draw() {
                            if (Math.random() > 0.9) {
                                var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

                                for (var i = 0; i < 2; i++) {
                                    var offSet = i;
                                    var randomColor = Math.floor(Math.random() * 9999999);
                                    var randomColorHexString = '#' + randomColor.toString(16);
                                    grad.addColorStop(offSet, randomColorHexString);
                                }

                                context.fillStyle = grad;
                            }
                            context.fillRect(0, 0, canvasWidth, canvasHeight);
                            context.drawImage(sprite, x, y);
                        }

                        function keyDown(e) {
                            e = e || window.event;

                            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;
                            }

                        }

                        function Update() {
                            var now = Date.now();
                            if (lastTime === 0) {
                                lastTime = now;
                            }
                            delta = now - lastTime;
                            teleportDelta = skipInterval * delta;
                            lastTime = now;
                        }

                        var fps = 60;
                        var intervalId = setInterval(function () {
                            Update();
                            Draw();
                        }, 1000 / fps);

                        document.onkeydown = keyDown;
                    }
                }
            </script>
            <img id="sprite" src=""/>
        </div>
    </body>
</html>


Beginner in Game Development? Read here.
 
Super Mario Bros clone tutorial written in XNA 4.0 [MonoGame, ANX, and MonoXNA] by Scott Haley
 
If you have found any of the posts helpful, please show your appreciation by clicking the up arrow on those posts Posted Image
 
Spoiler

#8 rip-off   Moderators   -  Reputation: 8223

Like
2Likes
Like

Posted 02 November 2013 - 12:36 PM

Adding more images:
<!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 style="display: none">
            <script>
                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;

                        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 = [];
						for(var i = 0 ; i < organIds.length ; ++i) {
							var organX = Math.random() * (canvasWidth - sprite.width);
							var organY = Math.random() * (canvasHeight - sprite.height);
							var organImage = document.getElementById(organIds[i]);
							organs.push({image: organImage, x: organX, y: organY})
						}

                        function Draw() {
                            if (Math.random() > 0.9) {
                                var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

                                for (var i = 0; i < 2; i++) {
                                    var offSet = i;
                                    var randomColor = Math.floor(Math.random() * 9999999);
                                    var randomColorHexString = '#' + randomColor.toString(16);
                                    grad.addColorStop(offSet, randomColorHexString);
                                }

                                context.fillStyle = grad;
                            }
                            context.fillRect(0, 0, canvasWidth, canvasHeight);
							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 keyDown(e) {
                            e = e || window.event;

                            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;
                            }

                        }

                        function Update() {
                            var now = Date.now();
                            if (lastTime === 0) {
                                lastTime = now;
                            }
                            delta = now - lastTime;
                            teleportDelta = skipInterval * delta;
                            lastTime = now;
                        }

                        var fps = 60;
                        var intervalId = setInterval(function () {
                            Update();
                            Draw();
                        }, 1000 / fps);

                        document.onkeydown = keyDown;
                    }
                }
            </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>


#9 froop   Members   -  Reputation: 636

Like
3Likes
Like

Posted 02 November 2013 - 12:40 PM

Did some refactoring to have a real delta. Movement was determined by the key repeat frequency before. Also made use of the unused variable 'keys' introduced in my first commit.

 

Edit: Merged rip-off's last commit

Edit Edit: Converted tabs to spaces

Edit Edit Edit: Forgot some of rip-off's code. Truly horrifying!

<!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 style="display: none">
            <script>
                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;

                        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 = [];
                        for(var i = 0 ; i < organIds.length ; ++i) {
                            var organX = Math.random() * (canvasWidth - sprite.width);
                            var organY = Math.random() * (canvasHeight - sprite.height);
                            var organImage = document.getElementById(organIds[i]);
                            organs.push({image: organImage, x: organX, y: organY})
                        }

                        function Draw() {
                            if (Math.random() > 0.9) {
                                var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

                                for (var i = 0; i < 2; i++) {
                                    var offSet = i;
                                    var randomColor = Math.floor(Math.random() * 9999999);
                                    var randomColorHexString = '#' + randomColor.toString(16);
                                    grad.addColorStop(offSet, randomColorHexString);
                                }

                                context.fillStyle = grad;
                            }
                            context.fillRect(0, 0, canvasWidth, canvasHeight);

                            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;
                            teleportDelta = skipInterval * delta;
                            lastTime = now;
                            
                            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>

Edited by froop, 02 November 2013 - 12:52 PM.


#10 Alpha_ProgDes   Crossbones+   -  Reputation: 4688

Like
2Likes
Like

Posted 02 November 2013 - 01:10 PM

Changed teleportDelta to skipDelta.

<!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 style="display: none">
            <script>
                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;

                        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 = [];
                        for (var i = 0 ; i < organIds.length ; ++i) {
                            var organX = Math.random() * (canvasWidth - sprite.width);
                            var organY = Math.random() * (canvasHeight - sprite.height);
                            var organImage = document.getElementById(organIds[i]);
                            organs.push({ image: organImage, x: organX, y: organY })
                        }

                        function Draw() {
                            if (Math.random() > 0.9) {
                                var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

                                for (var i = 0; i < 2; i++) {
                                    var offSet = i;
                                    var randomColor = Math.floor(Math.random() * 9999999);
                                    var randomColorHexString = '#' + randomColor.toString(16);
                                    grad.addColorStop(offSet, randomColorHexString);
                                }

                                context.fillStyle = grad;
                            }
                            context.fillRect(0, 0, canvasWidth, canvasHeight);

                            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;

                            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>

Beginner in Game Development? Read here.
 
Super Mario Bros clone tutorial written in XNA 4.0 [MonoGame, ANX, and MonoXNA] by Scott Haley
 
If you have found any of the posts helpful, please show your appreciation by clicking the up arrow on those posts Posted Image
 
Spoiler

#11 rip-off   Moderators   -  Reputation: 8223

Like
2Likes
Like

Posted 02 November 2013 - 02:36 PM

Making new images transparent:

<!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;

                        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 = [];
                        for (var i = 0 ; i < organIds.length ; ++i) {
                            var organX = Math.random() * (canvasWidth - sprite.width);
                            var organY = Math.random() * (canvasHeight - sprite.height);
                            var organImage = document.getElementById(organIds[i]);
                            organs.push({ image: makeTransparent(organImage), x: organX, y: organY })
                        }

                        function Draw() {
                            if (Math.random() > 0.9) {
                                var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

                                for (var i = 0; i < 2; i++) {
                                    var offSet = i;
                                    var randomColor = Math.floor(Math.random() * 9999999);
                                    var randomColorHexString = '#' + randomColor.toString(16);
                                    grad.addColorStop(offSet, randomColorHexString);
                                }

                                context.fillStyle = grad;
                            }
                            context.fillRect(0, 0, canvasWidth, canvasHeight);

                            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;

                            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>

2c1j.png


Edited by rip-off, 02 November 2013 - 02:48 PM.


#12 froop   Members   -  Reputation: 636

Like
1Likes
Like

Posted 02 November 2013 - 09:32 PM

Need more organs

<!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;

                        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 });
                        }

                        function Draw() {
                            if (Math.random() > 0.9) {
                                var grad = context.createLinearGradient(0, 0, canvasWidth, canvasHeight);

                                for (var i = 0; i < 2; i++) {
                                    var offSet = i;
                                    var randomColor = Math.floor(Math.random() * 9999999);
                                    var randomColorHexString = '#' + randomColor.toString(16);
                                    grad.addColorStop(offSet, randomColorHexString);
                                }

                                context.fillStyle = grad;
                            }
                            context.fillRect(0, 0, canvasWidth, canvasHeight);

                            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;

                            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>

zhzv.png


Edited by froop, 02 November 2013 - 09:56 PM.


#13 rip-off   Moderators   -  Reputation: 8223

Like
0Likes
Like

Posted 03 November 2013 - 10:48 AM

Made the gradient look vaguely like lightning (you might be able to tell I'm not much of a graphics programmer!):

<!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 });
                        }
 
                        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;
 
                            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>

lightning.png


Edited by rip-off, 03 November 2013 - 10:55 AM.


#14 staunsholm   Members   -  Reputation: 247

Like
3Likes
Like

Posted 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.



#15 froop   Members   -  Reputation: 636

Like
1Likes
Like

Posted 03 November 2013 - 04:12 PM

Added some movement, and heavy shaking when lightning strikes.

 

LOL that's awesome



#16 froop   Members   -  Reputation: 636

Like
1Likes
Like

Posted 03 November 2013 - 05:20 PM

Now when Frankenstein hits an organ, it will explode in a bloody mess!

image.png

 

PS: Seems like we've broken Internet Explorer compatiblity :( I get a "SCRIPT5022: IndexSizeError" in line 30. Anyone know what's up?

<!DOCTYPE html>
<html>
<head>
    <title>Horror!</title>
    <style type="text/css">
        body {
            text-align:center;
            margin: 0;
            padding: 0;
        }
    </style>
</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;
        }
        
        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'];
                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;
                        }
                    }
                }

                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=""/>
</div>
</body>
</html>

Edited by froop, 03 November 2013 - 05:37 PM.


#17 Alpha_ProgDes   Crossbones+   -  Reputation: 4688

Like
0Likes
Like

Posted 03 November 2013 - 09:24 PM

Added ghosts.

<!DOCTYPE html>
<html>
<head>
    <title>Horror!</title>
    <style type="text/css">
        body {
            text-align:center;
            margin: 0;
            padding: 0;
        }
    </style>
</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); //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;
                        }
                    }
                }
 
                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>
</body>
</html>

Edited by rip-off, 04 November 2013 - 05:02 PM.

Beginner in Game Development? Read here.
 
Super Mario Bros clone tutorial written in XNA 4.0 [MonoGame, ANX, and MonoXNA] by Scott Haley
 
If you have found any of the posts helpful, please show your appreciation by clicking the up arrow on those posts Posted Image
 
Spoiler

#18 rip-off   Moderators   -  Reputation: 8223

Like
1Likes
Like

Posted 04 November 2013 - 05:33 PM

Constrain frank to the visible area:

<!DOCTYPE html>
<html>
<head>
    <title>Horror!</title>
    <style type="text/css">
        body {
            text-align:center;
            margin: 0;
            padding: 0;
        }
    </style>
</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); //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>
</body>
</html>

Edited by rip-off, 04 November 2013 - 05:34 PM.


#19 Shippou   Members   -  Reputation: 1528

Like
0Likes
Like

Posted 20 November 2013 - 01:05 AM

Now has a border around the frame. If I have time, I'll add in some framework for game functions.

<!DOCTYPE html>
<html>
<head>
    <title>Horror!</title>
    <style type="text/css">
        body {
            text-align:center;
            margin: 0;
            padding: 0;
        }
    </style>
</head>
<body>
<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>
</body>
</html>

 Reactions To Technologies:
1. Anything that is in the world when you’re born is normal and ordinary and is just a natural part of the way the world works.
2. Anything that's invented between when you’re fifteen and thirty-five is new and exciting and revolutionary and you can probably get a career in it.
3. Anything invented after you're thirty-five is against the natural order of things.

- Douglas Adams 2002


 


#20 Shippou   Members   -  Reputation: 1528

Like
0Likes
Like

Posted 23 November 2013 - 07:03 AM

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>

 Reactions To Technologies:
1. Anything that is in the world when you’re born is normal and ordinary and is just a natural part of the way the world works.
2. Anything that's invented between when you’re fifteen and thirty-five is new and exciting and revolutionary and you can probably get a career in it.
3. Anything invented after you're thirty-five is against the natural order of things.

- Douglas Adams 2002


 






PARTNERS