Color Pong Game
a very simple pong game with randomly changing colors. Can you score more than 50? :)
<html>
<head>
<meta charset="utf-8">
<title>Color Pong v0.1</title>
</head>
<body>
<div id="g"></div>
<div id="shine"></div>
<canvas id="c"></canvas>
<audio preload="true" id="snd">
<source src="http://www.mcalister.ch/lab/colorpong/c.wav"/>
</audio>
<div id="link"><a href="http://www.lemu.ch">www.lemu.ch</a></div>
</body>
</html>
html, body {
html, body {
width: 100%;
height: 100%;
margin: 0px;
padding: 0px;
text-align: center;
}
#g{
position:absolute;
width:100%;
height:100%;
background: linear-gradient(top, rgba(255,255,255,0) 50%, rgba(255,255,255,0.25) 100%);
background: gradient(linear, left top, left bottom, color-stop(50%,rgba(255,255,255,0)), color-stop(100%,rgba(255,255,255,0.25)));
background: linear-gradient(top, rgba(255,255,255,0) 50%,rgba(255,255,255,0.25) 100%);
background: linear-gradient(top, rgba(255,255,255,0) 50%,rgba(255,255,255,0.25) 100%);
background: linear-gradient(top, rgba(255,255,255,0) 50%,rgba(255,255,255,0.25) 100%);
background: linear-gradient(to bottom, rgba(255,255,255,0) 50%,rgba(255,255,255,0.25) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#40ffffff',GradientType=0 );
}
#c{
margin:-150px 0 0 -200px;
position:absolute;
top:50%;
left:50%;
box-shadow: 0 0 3px 0px rgba(0,0,0,0.4);
box-shadow: 0 0 3px 0px rgba(0,0,0,0.4);
box-shadow: 0 0 3px 0px rgba(0,0,0,0.4);
box-shadow: 0 0 3px 0px rgba(0,0,0,0.4);
border:5px solid #262626;
box-reflect: below 0px gradient(linear, left top, left bottom, from(transparent), color-stop(70%, transparent), to(rgba(255,255,255,0.15)));
}
#shine{
width:400px;
height:300px;
position:absolute;
top:50%;
left:50%;
margin-left:-195px;
margin-top:-145px;
z-index:9999;
background-image:url(%3D%3D);
opacity:0.4;
}
#link{
position:absolute;
right:10px;
bottom:10px;
}
#link a{
color:#262626;
text-shadow:0 1px 1px rgba(255,255,255,0.3);
text-decoration:none;
font-size:10px;
font-family:"Helvetica Neue", Helvetica, Arial, sans-serif;
transition:font-size 0.2s ease-in-out;
}
#link a:hover{
font-size:14px;
}
/////////////////////////////
/////////////////////////////
// Color Pong v0.1 //
// by Brian Mc Alister //
// //
// work in progress //
/////////////////////////////
// init canvas
var canvas = document.getElementById("c");
var ctx= canvas.getContext("2d");
canvas.width = 400;
canvas.height = 300;
// set global vars
var score = 0;
var highscore = 0;
var collision = false;
var fl = 0;
var fr = 0;
var logo = new Image(); // Create new img element
logo.src = "";
snd = document.getElementById("snd");
// function for random color
function randcol(){
// random 70 through 255 (so its never too dark)
var start = 70;
return start + Math.round(Math.random() * (255-start));
}
// initialize objects
var bar = {
height: 5,
width: 70,
x: 0,
y: canvas.height-this.height,
r: 255,
g: 255,
b: 255
}
var ball = {
y: 0,
x: 0,
width: 5,
height: 5,
speedx: 200,
speedy: -200
}
var ball2 = {
width: ball.width,
height: ball.height,
x: ball.width*2*(-1),
y: ball.height*2*(-1),
r: 255,
g: 255,
b: 255,
a: 1
}
var reset = function () {
//initialize bar on left
bar.x=0;
bar.y=canvas.height-bar.height;
//set speed so ball goes up first
ball.speedy = -200;
ball.speedx = 200;
// reset score
score = 0;
// Place ball on screen randomly (halfway on y axis)
ball.x = (Math.random() * (canvas.width - 5));
ball.y = (canvas.width/2)-(ball.height/2);
};
function resetball2(){
// hide ball2
ball2.x=ball2.width*(-1);
ball2.y=ball2.height*(-1);
//set same size as ball
ball2.width=ball.width;
ball2.height=ball.height;
// get random color
ball2.r = randcol();
ball2.g = randcol();
ball2.b = randcol();
// set alpha = 1
ball2.a = 1;
}
// function for updating bar X position
function follow(e)
{
v = e.pageX - canvas.offsetLeft -bar.width/2;
if (v < 0){v = 0;}
if (v > canvas.width-bar.width){v = canvas.width-bar.width;}
bar.x = v;
}
// update bar x position
window.addEventListener("mousemove",follow,false);
var update = function (modifier) {
//update ball position
ball.x = ball.x+(ball.speedx*modifier);
ball.y= ball.y+(ball.speedy*modifier);
// collision ball
if (collision == true){
if (ball2.a > 0){ball2.width = ball2.width+1000*modifier;
ball2.height=ball2.height+1000*modifier;
ball2.x = ball.x;
ball2.y = ball.y;
ball2.a = ball2.a - 2*modifier;
}else{
collision = false;
resetball2();
}
}
// Is ball touching top?
if (ball.y <= (0) && ball.speedy < 0) {
//change direction
ball.speedy = ball.speedy * -1;
}
// Is ball touching left
if (ball.x <= (0) && ball.speedx < (0)){
ball.speedx = ball.speedx * -1;
}
// Is ball touching right
if (ball.x >= (canvas.width-ball.width) && ball.speedx > (0)){
ball.speedx = ball.speedx * -1;
}
// Is ball touching bar?
if (
ball.x+ball.width >= (bar.x)
&& ball.x <= (bar.x+bar.width)
&& ball.y+ball.height >= (bar.y)
&& ball.speedy > 0
) {
// reset sound and play
snd.currentTime = 0;
snd.play();
// update score
++score;
if (score > highscore){highscore = score;}
// increase speed
// boost X if ball hits corner of bar
if(ball.x+ball.width <= (bar.x+ball.width*2)){
// define flick size
fl = 10+(ball.width*2-((ball.x+ball.width)-bar.x))*5;
// always flick ball left
if(ball.speedx < 0){ball.speedx = ball.speedx-fl;}
if(ball.speedx > 0){ball.speedx = ball.speedx*(-1)-fl;}
}else if(ball.x >= (bar.x+bar.width-ball.width*2)){
// define flick size
fr = 10+(ball.width*2-((ball.x+ball.width)-(bar.x+bar.width)))*5;
// always flick ball right
if(ball.speedx < 0){ball.speedx = ball.speedx*(-1)+fr;}
if(ball.speedx > 0){ball.speedx = ball.speedx+fr;}
}else{
// Randomize x speed on central hit ((-20) to 20)
ball.speedx = ball.speedx + ((Math.random()*40)-20);
}
// update Y speed
ball.speedy = ball.speedy +20;
//change y direction of ball
ball.speedy = ball.speedy * -1;
//set collision true
collision=true;
//reset / initialize ball2
resetball2();
//set color
bar.r = ball2.r;
bar.g = ball2.g;
bar.b = ball2.b;
// set background color
document.body.style.background = "rgb("+bar.r+","+bar.g+","+bar.b+")";
}
// Is ball touching bottom?
if (ball.y >= (canvas.height-ball.height) && ball.speedy > 0) {
reset();
}
};
// Draw everything
var render = function () {
// set dark grey bg
ctx.fillStyle = '#262626';
ctx.fillRect(0,0,canvas.width,canvas.height);
// set logo
ctx.drawImage(logo,canvas.width/2-logo.width/2,canvas.height/2-logo.height/2);
// draw ball2 (collision effect)
ctx.beginPath();
ctx.fillStyle = "rgba("+ball2.r+","+ball2.g+","+ball2.b+","+ball2.a+")";
//ctx.fillRect(ball2.x,ball2.y,ball2.width,ball2.height);
ctx.arc(ball2.x+ball.width,bar.y,ball2.width,ball2.height, Math.PI*2, true);
ctx.fill();
ctx.closePath();
// draw ball
ctx.fillStyle = "rgb("+bar.r+","+bar.g+","+bar.b+")";
ctx.fillRect(ball.x,ball.y,ball.width,ball.height);
// draw bar
ctx.fillStyle = "rgb("+bar.r+","+bar.g+","+bar.b+")";
ctx.fillRect(bar.x,bar.y,bar.width,bar.height);
// Score
ctx.fillStyle = "rgb(250, 250, 250)";
ctx.font = "12px Helvetica";
ctx.textAlign = "right";
ctx.textBaseline = "top";
ctx.fillText("score: " + score, canvas.width-10, 23);
// HighScore
ctx.fillStyle = "rgb(250, 250, 250)";
ctx.font = "bold 12px Helvetica";
ctx.textAlign = "right";
ctx.textBaseline = "top";
ctx.fillText("best: " + highscore, canvas.width-10, 10);
};
var main = function () {
var now = Date.now();
var delta = now - then;
update(delta / 1000);
render();
then = now;
};
reset();
var then = Date.now();
setInterval(main, 1);