<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Feed the Snake v 1.1 beta</title>
<style>
body
{
background:#000;
color:#FFF;
}
canvas
{
background:#FFF;
}
#controls
{
position:absolute;
top:0;
right:0;
margin:10px;
}
</style>
<script type="text/javascript">
var snake = window.snake || {};
function launchFullscreen(element) {
if(element.requestFullscreen) {
element.requestFullscreen();
} else if(element.mozRequestFullScreen) {
element.mozRequestFullScreen();
} else if(element.webkitRequestFullscreen) {
element.webkitRequestFullscreen();
} else if(element.msRequestFullscreen) {
element.msRequestFullscreen();
}
}
window.onload = function(){
document.addEventListener("fullscreenchange", function(){snake.game.adjust();});
document.addEventListener("webkitfullscreenchange", function(){snake.game.adjust();});
document.addEventListener("mozfullscreenchange", function(){snake.game.adjust();});
document.addEventListener("MSFullscreenChange", function(){snake.game.adjust();});
snake.game = (function()
{
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
var status=false;
var score = 0;
var old_direction = 'right';
var direction = 'right';
var block = 10;
var score = 0;
var refresh_rate = 250;
var pos = [[5,1],[4,1],[3,1],[2,1],[1,1]];
var scoreboard = document.getElementById('scoreboard');
var control = document.getElementById('controls');
var keys = {
37 : 'left',
38 : 'up',
39 : 'right',
40 : 'down'
};
function adjust()
{
if (document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement )
{
canvas.width=window.innerWidth;
canvas.height=window.innerHeight;
control.style.display='none';
}
else
{
canvas.width=850;
canvas.height=600;
control.style.display='inline';
}
}
var food
= [Math.
round(Math.
random(4)*(canvas.
width - 10)),
Math.
round(Math.
random(4)*(canvas.
height - 10)),
]; function todraw()
{
for(var i = 0; i < pos.length; i++)
{
draw(pos[i]);
}
}
function giveLife()
{
var nextPosition = pos[0].slice();
switch(old_direction)
{
case 'right':
nextPosition[0] += 1;
break;
case 'left':
nextPosition[0] -= 1;
break;
case 'up':
nextPosition[1] -= 1;
break;
case 'down':
nextPosition[1] += 1;
break;
}
pos.unshift(nextPosition);
pos.pop();
}
function grow()
{
var nextPosition = pos[0].slice();
switch(old_direction)
{
case 'right':
nextPosition[0] += 1;
break;
case 'left':
nextPosition[0] -= 1;
break;
case 'up':
nextPosition[1] -= 1;
break;
case 'down':
nextPosition[1] += 1;
break;
}
pos.unshift(nextPosition);
}
function loop()
{
ctx.clearRect(0,0,canvas.width,canvas.height);
todraw();
giveLife();
feed();
if(is_catched(pos[0][0]*block,pos[0][1]*block,block,block,food[0],food[1],10,10))
{
score += 10;
createfood();
scoreboard.innerHTML = score;
grow();
if(refresh_rate > 100)
{
refresh_rate -=5;
}
}
snake.game.status = setTimeout(function() { loop(); },refresh_rate);
}
window.onkeydown = function(event){
direction = keys[event.keyCode];
if(direction)
{
setWay(direction);
event.preventDefault();
}
};
function setWay(direction)
{
switch(direction)
{
case 'left':
if(old_direction!='right')
{
old_direction = direction;
}
break;
case 'right':
if(old_direction!='left')
{
old_direction = direction;
}
break;
case 'up':
if(old_direction!='down')
{
old_direction = direction;
}
break;
case 'down':
if(old_direction!='up')
{
old_direction = direction;
}
break;
}
}
function feed()
{
ctx.beginPath();
ctx.fillStyle = "#ff0000";
ctx.fillRect(food[0],food[1],10,10);
ctx.fill();
ctx.closePath();
}
function createfood()
{
}
function is_catched(ax,ay,awidth,aheight,bx,by,bwidth,bheight) {
return !(
((ay + aheight) < (by)) ||
(ay > (by + bheight)) ||
((ax + awidth) < bx) ||
(ax > (bx + bwidth))
);
}
function draw(pos)
{
var x = pos[0] * block;
var y = pos[1] * block;
if(x >= canvas.width || x <= 0 || y >= canvas.height || y<= 0)
{
document.getElementById('pause').disabled='true';
snake.game.status=false;
ctx.clearRect(0,0,canvas.width,canvas.height);
ctx.font='40px san-serif';
ctx.fillText('Game Over',300,250);
ctx.font = '20px san-serif';
ctx.fillStyle='#000000';
ctx.fillText('To Play again Refresh the page or click the Restarts button',200,300);
throw ('Game Over');
}
else
{
ctx.beginPath();
ctx.fillStyle='#000000';
ctx.fillRect(x,y,block,block);
ctx.closePath();
}
}
function pause(elem)
{
if(snake.game.status)
{
clearTimeout(snake.game.status);
snake.game.status=false;
elem.value='Play'
}
else
{
loop();
elem.value='Pause';
}
}
function begin()
{
loop();
}
function restart()
{
location.reload();
}
function start()
{
ctx.fillStyle='#000000';
ctx.fillRect(0,0,canvas.width,canvas.height);
ctx.fillStyle='#ffffff';
ctx.font='40px helvatica';
ctx.fillText('ZeX_EVO',370,140);
ctx.font='20px san-serif';
ctx.fillText('presents',395,190);
ctx.font='italic 60px san-serif';
ctx.fillText('Friendly Snake',240,280);
img.onload = function()
{
ctx.drawImage(img,300,300,200,200);
ctx.fillRect(410,330,10,10);
}
img.src ='snake.png';
}
function fullscreen()
{
launchFullscreen(canvas);
}
return {
pause: pause,
restart : restart,
start : start,
begin: begin,
fullscreen : fullscreen,
adjust : adjust,
};
})();
snake.game.start();
}
</script>
</head>
<body>
<canvas width="850" height="600" id="canvas" style="border:1px solid #333;" onclick="snake.game.begin();">
</canvas>
<div id="controls" style="float:right; text-align:center;">
<input type="button" id="pause" value="Play" onClick="snake.game.pause(this);" accesskey="p">
<input type="button" id="restart" value="Restart" onClick="snake.game.restart();">
<br/><br/>
<input type="button" id="fullscreen" value="Play Fullscreen" onClick="snake.game.fullscreen();">
<br/><br/>
<div style="font-size:24px;">
Score :
<span id="scoreboard">0</span>
</div>
</div>
</body>
</html>
You can see a live version of the game here.
javascript html5 canvas snake-game
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Feed the Snake v 1.1 beta</title>
<style>
body
{
    background:#000;
    color:#FFF;
}
canvas
{
    background:#FFF;
}
#controls
{
    position:absolute;
    top:0;
    right:0;
    margin:10px;
}
</style>
<script type="text/javascript">
var snake = window.snake || {};
function launchFullscreen(element) {
  if(element.requestFullscreen) {
    element.requestFullscreen();
  } else if(element.mozRequestFullScreen) {
    element.mozRequestFullScreen();
  } else if(element.webkitRequestFullscreen) {
    element.webkitRequestFullscreen();
  } else if(element.msRequestFullscreen) {
    element.msRequestFullscreen();
  }
}
window.onload = function(){
    document.addEventListener("fullscreenchange", function(){snake.game.adjust();});
    document.addEventListener("webkitfullscreenchange", function(){snake.game.adjust();});
    document.addEventListener("mozfullscreenchange", function(){snake.game.adjust();});
    document.addEventListener("MSFullscreenChange", function(){snake.game.adjust();});

    snake.game = (function()
    {
        var canvas = document.getElementById('canvas');
        var ctx = canvas.getContext('2d');
        var status=false;
        var score = 0;
        var old_direction = 'right';
        var direction = 'right';
        var block = 10;
        var score = 0;
        var refresh_rate = 250;
        var pos = [[5,1],[4,1],[3,1],[2,1],[1,1]];
        var scoreboard = document.getElementById('scoreboard');
        var control = document.getElementById('controls');
        var keys = {
            37 : 'left',
            38 : 'up',
            39 : 'right',
            40 : 'down'
            };
        function adjust()
        {
            if (document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement )
            {
                canvas.width=window.innerWidth;
                canvas.height=window.innerHeight;
                control.style.display='none';
            }
            else
            {
                canvas.width=850;
                canvas.height=600;
                control.style.display='inline';
            }
        }
        var food = [Math.round(Math.random(4)*(canvas.width - 10)), Math.round(Math.random(4)*(canvas.height - 10)),];
        function todraw()
        {
            for(var i = 0; i < pos.length; i++)
            {
                draw(pos[i]);
            }
        }
        function giveLife()
        {
            var nextPosition = pos[0].slice();
            switch(old_direction)
            {
                case 'right':
                    nextPosition[0] += 1;
                    break;
                case 'left':
                    nextPosition[0] -= 1;
                    break;
                case 'up':
                    nextPosition[1] -= 1;
                    break;
                case 'down':
                    nextPosition[1] += 1;
                    break;    
            }
            pos.unshift(nextPosition);
            pos.pop();
        }
        function grow()
        {
            var nextPosition = pos[0].slice();
            switch(old_direction)
            {
                case 'right':
                    nextPosition[0] += 1;
                    break;
                case 'left':
                    nextPosition[0] -= 1;
                    break;
                case 'up':
                    nextPosition[1] -= 1;
                    break;
                case 'down':
                    nextPosition[1] += 1;
                    break;    
            }
            pos.unshift(nextPosition);
        }
        function loop()
        {
            ctx.clearRect(0,0,canvas.width,canvas.height);
            todraw();
            giveLife();
            feed();
            if(is_catched(pos[0][0]*block,pos[0][1]*block,block,block,food[0],food[1],10,10))
            {
                score += 10;
                createfood();
                scoreboard.innerHTML = score;
                grow();
                if(refresh_rate > 100)
                {
                    refresh_rate -=5;
                }
            }
            snake.game.status = setTimeout(function() { loop(); },refresh_rate);
        }
        window.onkeydown = function(event){
             direction = keys[event.keyCode];
                if(direction)
                {
                    setWay(direction);
                    event.preventDefault();
                }
            };
        function setWay(direction)
        {
            switch(direction)
            {
                case 'left':
                    if(old_direction!='right')
                    {
                        old_direction = direction;
                    }
                    break;
                case 'right':
                    if(old_direction!='left')
                    {
                        old_direction = direction;
                    }
                    break;
                case 'up':
                    if(old_direction!='down')
                    {
                        old_direction = direction;
                    }
                    break;
                case 'down':
                    if(old_direction!='up')
                    {
                        old_direction = direction;
                    }
                    break;
            }

        }
        function feed()
        {
            ctx.beginPath();
            ctx.fillStyle = "#ff0000";
            ctx.fillRect(food[0],food[1],10,10);
            ctx.fill();
            ctx.closePath();
        }
        function createfood()
        {
            food = [Math.round(Math.random(4)*850), Math.round(Math.random(4)*600)];
        }
        function is_catched(ax,ay,awidth,aheight,bx,by,bwidth,bheight) {
            return !(
            ((ay + aheight) < (by)) ||
            (ay > (by + bheight)) ||
            ((ax + awidth) < bx) ||
            (ax > (bx + bwidth))
            );
        }
        function draw(pos)
        {
            var x = pos[0] * block;
            var y = pos[1] * block;
            if(x >= canvas.width || x <= 0 || y >= canvas.height || y<= 0)
            {
                    document.getElementById('pause').disabled='true';
                    snake.game.status=false;
                    ctx.clearRect(0,0,canvas.width,canvas.height);
                    ctx.font='40px san-serif';
                    ctx.fillText('Game Over',300,250);
                    ctx.font = '20px san-serif';
                    ctx.fillStyle='#000000';
                    ctx.fillText('To Play again Refresh the page or click the Restarts button',200,300);
                    throw ('Game Over');
            }
            else
            {
                ctx.beginPath();
                ctx.fillStyle='#000000';
                ctx.fillRect(x,y,block,block);
                ctx.closePath();
            }
        }
        function pause(elem)
        {
            if(snake.game.status)
            {
                clearTimeout(snake.game.status);
                snake.game.status=false;
                elem.value='Play'
            }
            else
            {
                loop();
                elem.value='Pause';
            }
        }
        function begin()
        {
            loop();
        }
        function restart()
        {
            location.reload();
        }
        function start()
        {
            ctx.fillStyle='#000000';
            ctx.fillRect(0,0,canvas.width,canvas.height);
            ctx.fillStyle='#ffffff';
            ctx.font='40px helvatica';
            ctx.fillText('ZeX_EVO',370,140);
            ctx.font='20px san-serif';
            ctx.fillText('presents',395,190);
            ctx.font='italic 60px san-serif';
            ctx.fillText('Friendly Snake',240,280);
            var img = new Image();
            img.onload = function()
            {
                ctx.drawImage(img,300,300,200,200);
                ctx.fillRect(410,330,10,10);
            }
            img.src ='snake.png';
        }
        function fullscreen()
        {
            launchFullscreen(canvas);
        }
        return {
            pause: pause,
            restart : restart,
            start : start,
            begin: begin,
            fullscreen : fullscreen,
            adjust : adjust,
        };
    })();
    snake.game.start();
}
</script>
</head>
<body>
<canvas width="850" height="600" id="canvas" style="border:1px solid #333;" onclick="snake.game.begin();">
</canvas>
<div id="controls" style="float:right; text-align:center;">
    <input type="button" id="pause" value="Play" onClick="snake.game.pause(this);" accesskey="p">
    <input type="button" id="restart" value="Restart" onClick="snake.game.restart();">
    <br/><br/>
    <input type="button" id="fullscreen" value="Play Fullscreen" onClick="snake.game.fullscreen();">
    <br/><br/>
    <div style="font-size:24px;">
    Score : 
    <span id="scoreboard">0</span>
    </div>
</div>
</body>
</html>
You can see a live version of the game here.

javascript html5 canvas snake-game
Main.java:1: error: class, interface, or enum expected
<!DOCTYPE HTML>
^
Main.java:1: error: class, interface, or enum expected
<!DOCTYPE HTML>
^
Main.java:1: error: class, interface, or enum expected
<!DOCTYPE HTML>
^
Main.java:9: error: illegal character: '#'
background:#000;
^
Main.java:10: error: class, interface, or enum expected
color:#FFF;
^
Main.java:10: error: illegal character: '#'
color:#FFF;
^
Main.java:11: error: class, interface, or enum expected
}
^
Main.java:14: error: illegal character: '#'
background:#FFF;
^
Main.java:15: error: class, interface, or enum expected
}
^
Main.java:16: error: illegal character: '#'
#controls
^
Main.java:19: error: class, interface, or enum expected
top:0;
^
Main.java:20: error: class, interface, or enum expected
right:0;
^
Main.java:21: error: class, interface, or enum expected
margin:10px;
^
Main.java:22: error: class, interface, or enum expected
}
^
Main.java:26: error: class, interface, or enum expected
function launchFullscreen(element) {
^
Main.java:29: error: class, interface, or enum expected
} else if(element.mozRequestFullScreen) {
^
Main.java:31: error: class, interface, or enum expected
} else if(element.webkitRequestFullscreen) {
^
Main.java:33: error: class, interface, or enum expected
} else if(element.msRequestFullscreen) {
^
Main.java:35: error: class, interface, or enum expected
}
^
Main.java:38: error: class, interface, or enum expected
document.addEventListener("fullscreenchange", function(){snake.game.adjust();});
^
Main.java:39: error: class, interface, or enum expected
document.addEventListener("webkitfullscreenchange", function(){snake.game.adjust();});
^
Main.java:39: error: class, interface, or enum expected
document.addEventListener("webkitfullscreenchange", function(){snake.game.adjust();});
^
Main.java:40: error: class, interface, or enum expected
document.addEventListener("mozfullscreenchange", function(){snake.game.adjust();});
^
Main.java:40: error: class, interface, or enum expected
document.addEventListener("mozfullscreenchange", function(){snake.game.adjust();});
^
Main.java:41: error: class, interface, or enum expected
document.addEventListener("MSFullscreenChange", function(){snake.game.adjust();});
^
Main.java:41: error: class, interface, or enum expected
document.addEventListener("MSFullscreenChange", function(){snake.game.adjust();});
^
Main.java:43: error: class, interface, or enum expected
snake.game = (function()
^
Main.java:45: error: unclosed character literal
var canvas = document.getElementById('canvas');
^
Main.java:45: error: unclosed character literal
var canvas = document.getElementById('canvas');
^
Main.java:46: error: class, interface, or enum expected
var ctx = canvas.getContext('2d');
^
Main.java:46: error: unclosed character literal
var ctx = canvas.getContext('2d');
^
Main.java:46: error: unclosed character literal
var ctx = canvas.getContext('2d');
^
Main.java:47: error: class, interface, or enum expected
var status=false;
^
Main.java:48: error: class, interface, or enum expected
var score = 0;
^
Main.java:49: error: class, interface, or enum expected
var old_direction = 'right';
^
Main.java:49: error: unclosed character literal
var old_direction = 'right';
^
Main.java:49: error: unclosed character literal
var old_direction = 'right';
^
Main.java:50: error: unclosed character literal
var direction = 'right';
^
Main.java:50: error: unclosed character literal
var direction = 'right';
^
Main.java:52: error: class, interface, or enum expected
var score = 0;
^
Main.java:53: error: class, interface, or enum expected
var refresh_rate = 250;
^
Main.java:54: error: class, interface, or enum expected
var pos = [[5,1],[4,1],[3,1],[2,1],[1,1]];
^
Main.java:55: error: class, interface, or enum expected
var scoreboard = document.getElementById('scoreboard');
^
Main.java:55: error: unclosed character literal
var scoreboard = document.getElementById('scoreboard');
^
Main.java:55: error: unclosed character literal
var scoreboard = document.getElementById('scoreboard');
^
Main.java:56: error: class, interface, or enum expected
var control = document.getElementById('controls');
^
Main.java:56: error: unclosed character literal
var control = document.getElementById('controls');
^
Main.java:56: error: unclosed character literal
var control = document.getElementById('controls');
^
Main.java:57: error: class, interface, or enum expected
var keys = {
^
Main.java:58: error: unclosed character literal
37 : 'left',
^
Main.java:58: error: unclosed character literal
37 : 'left',
^
Main.java:59: error: unclosed character literal
38 : 'up',
^
Main.java:59: error: unclosed character literal
38 : 'up',
^
Main.java:60: error: unclosed character literal
39 : 'right',
^
Main.java:60: error: unclosed character literal
39 : 'right',
^
Main.java:61: error: unclosed character literal
40 : 'down'
^
Main.java:61: error: illegal line end in character literal
40 : 'down'
^
Main.java:63: error: class, interface, or enum expected
function adjust()
^
Main.java:68: error: class, interface, or enum expected
canvas.height=window.innerHeight;
^
Main.java:69: error: class, interface, or enum expected
control.style.display='none';
^
Main.java:69: error: unclosed character literal
control.style.display='none';
^
Main.java:69: error: unclosed character literal
control.style.display='none';
^
Main.java:74: error: class, interface, or enum expected
canvas.height=600;
^
Main.java:75: error: class, interface, or enum expected
control.style.display='inline';
^
Main.java:75: error: unclosed character literal
control.style.display='inline';
^
Main.java:75: error: unclosed character literal
control.style.display='inline';
^
Main.java:79: error: class, interface, or enum expected
function todraw()
^
Main.java:81: error: class, interface, or enum expected
for(var i = 0; i < pos.length; i++)
^
Main.java:81: error: class, interface, or enum expected
for(var i = 0; i < pos.length; i++)
^
Main.java:84: error: class, interface, or enum expected
}
^
Main.java:89: error: class, interface, or enum expected
switch(old_direction)
^
Main.java:91: error: unclosed character literal
case 'right':
^
Main.java:91: error: unclosed character literal
case 'right':
^
Main.java:93: error: class, interface, or enum expected
break;
^
Main.java:94: error: class, interface, or enum expected
case 'left':
^
Main.java:94: error: unclosed character literal
case 'left':
^
Main.java:94: error: unclosed character literal
case 'left':
^
Main.java:96: error: class, interface, or enum expected
break;
^
Main.java:97: error: class, interface, or enum expected
case 'up':
^
Main.java:97: error: unclosed character literal
case 'up':
^
Main.java:97: error: unclosed character literal
case 'up':
^
Main.java:99: error: class, interface, or enum expected
break;
^
Main.java:100: error: class, interface, or enum expected
case 'down':
^
Main.java:100: error: unclosed character literal
case 'down':
^
Main.java:100: error: unclosed character literal
case 'down':
^
Main.java:102: error: class, interface, or enum expected
break;
^
Main.java:103: error: class, interface, or enum expected
}
^
Main.java:105: error: class, interface, or enum expected
pos.pop();
^
Main.java:106: error: class, interface, or enum expected
}
^
Main.java:110: error: class, interface, or enum expected
switch(old_direction)
^
Main.java:112: error: unclosed character literal
case 'right':
^
Main.java:112: error: unclosed character literal
case 'right':
^
Main.java:114: error: class, interface, or enum expected
break;
^
Main.java:115: error: class, interface, or enum expected
case 'left':
^
Main.java:115: error: unclosed character literal
case 'left':
^
Main.java:115: error: unclosed character literal
case 'left':
^
Main.java:117: error: class, interface, or enum expected
break;
^
Main.java:118: error: class, interface, or enum expected
case 'up':
^
Main.java:118: error: unclosed character literal
case 'up':
^
Main.java:118: error: unclosed character literal
case 'up':
^
100 errors