Ajax Loader
HTML
<!DOCTYPE HTML>
1
<!DOCTYPE HTML>
2
<html>
3
<head>
4
<meta charset="utf-8">
5
<title>Color Pong v0.1</title>
6
</head>
7
<body>
8
<div id="g"></div>
9
<div id="shine"></div>
10
<canvas id="c"></canvas>
11
 
12
<audio preload="true" id="snd">
13
  <source src="http://www.mcalister.ch/lab/colorpong/c.wav"/>
14
</audio>
15
  
16
  <div id="link"><a href="http://www.lemu.ch">www.lemu.ch</a></div>
17
</body>
18
</html>
 
CSS
html, body {
1
html, body {
2
  width:  100%;
3
  height: 100%;
4
  margin: 0px;
5
  padding: 0px;
6
  text-align: center;
7
}
8
  
9
#g{
10
  position:absolute;
11
  width:100%;
12
  height:100%;
13
  
14
  background: -moz-linear-gradient(top,  rgba(255,255,255,0) 50%, rgba(255,255,255,0.25) 100%);
15
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%,rgba(255,255,255,0)), color-stop(100%,rgba(255,255,255,0.25)));
16
  background: -webkit-linear-gradient(top,  rgba(255,255,255,0) 50%,rgba(255,255,255,0.25) 100%);
17
  background: -o-linear-gradient(top,  rgba(255,255,255,0) 50%,rgba(255,255,255,0.25) 100%);
18
  background: -ms-linear-gradient(top,  rgba(255,255,255,0) 50%,rgba(255,255,255,0.25) 100%);
19
  background: linear-gradient(to bottom,  rgba(255,255,255,0) 50%,rgba(255,255,255,0.25) 100%);
20
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#40ffffff',GradientType=0 );
21
}  
22
 
23
#c{
24
  margin:-150px 0 0 -200px;
25
  position:absolute;
26
  top:50%;
27
  left:50%;
28
  -moz-box-shadow: 0 0 3px 0px rgba(0,0,0,0.4);
29
  -webkit-box-shadow: 0 0 3px 0px rgba(0,0,0,0.4);
30
  -o-box-shadow: 0 0 3px 0px rgba(0,0,0,0.4);
31
  box-shadow: 0 0 3px 0px rgba(0,0,0,0.4);
32
  border:5px solid #262626;
33
  -webkit-box-reflect: below 0px -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(70%, transparent), to(rgba(255,255,255,0.15)));
34
}
35
 
36
#shine{
37
    width:400px;
38
    height:300px;
39
    position:absolute;
40
    top:50%;
41
    left:50%;
42
    margin-left:-195px;
43
    margin-top:-145px;
44
  z-index:9999;
45
  background-image:url(%3D%3D);
46
  opacity:0.4;
47
}
48
 
49
#link{
50
  position:absolute;
51
  right:10px;
52
  bottom:10px;
53
}
54
 
55
#link a{
56
  color:#262626;
57
  text-shadow:0 1px 1px rgba(255,255,255,0.3);
58
  text-decoration:none;
59
  font-size:10px;
60
  font-family:"Helvetica Neue", Helvetica, Arial, sans-serif;
61
  transition:font-size 0.2s ease-in-out;
62
}
63
 
64
#link a:hover{
65
  font-size:14px;
66
}
 
JavaScript
/////////////////////////////
1
/////////////////////////////
2
//     Color Pong v0.1     //
3
//   by Brian Mc Alister   //
4
//                         //
5
//    work in progress     //
6
/////////////////////////////
7
 
8
// init canvas
9
var canvas = document.getElementById("c");
10
var ctx= canvas.getContext("2d");
11
canvas.width = 400;
12
canvas.height = 300;
13
 
14
// set global vars
15
var score = 0;
16
var highscore = 0;
17
var collision = false;
18
var fl = 0;
19
var fr = 0;
20
var logo = new Image();   // Create new img element
21
logo.src = "";
22
snd =  document.getElementById("snd");
23
 
24
 
25
// function for random color
26
function randcol(){
27
 
28
  // random 70 through 255 (so its never too dark)
29
  var start = 70;
30
  return start + Math.round(Math.random() * (255-start));
31
}
32
 
33
// initialize objects
34
var bar = {
35
  height: 5,
36
  width: 70,
37
  x: 0,
38
  y: canvas.height-this.height,
39
  r: 255,
40
  g: 255,
41
  b: 255
42
}
43
 
44
var ball = {
45
  y: 0,
46
  x: 0,
47
  width: 5,
48
  height: 5,
49
  speedx: 200,
50
  speedy: -200
51
}
52
 
53
var ball2 = {
54
  width: ball.width,
55
  height: ball.height,
56
  x: ball.width*2*(-1),
57
  y: ball.height*2*(-1),
58
  r: 255,
59
  g: 255,
60
  b: 255,
61
  a: 1
62
}
63
 
64
var reset = function () {
65
 
66
  //initialize bar on left
67
  bar.x=0;
68
  bar.y=canvas.height-bar.height;
69
  
70
  //set speed so ball goes up first
71
  ball.speedy = -200;
72
  ball.speedx = 200;
73
  
74
  // reset score
75
  score = 0;
76
 
77
  // Place ball on screen randomly (halfway on y axis)
78
  ball.x = (Math.random() * (canvas.width - 5));
79
  ball.y = (canvas.width/2)-(ball.height/2);
80
};
81
 
82
function resetball2(){
83
  // hide ball2
84
  ball2.x=ball2.width*(-1);
85
  ball2.y=ball2.height*(-1);
86
  
87
  //set same size as ball
88
  ball2.width=ball.width;
89
  ball2.height=ball.height;
90
  
91
  // get random color
92
  ball2.r = randcol();
93
  ball2.g = randcol();
94
  ball2.b = randcol();
95
  
96
  // set alpha = 1
97
  ball2.a = 1;
98
}
99
 
100
// function for updating bar X position
101
function follow(e)
102
{
103
  v = e.pageX - canvas.offsetLeft -bar.width/2;
104
  if (v < 0){v = 0;}
105
  if (v > canvas.width-bar.width){v = canvas.width-bar.width;}
106
 
107
  bar.x = v;
108
}
109
 
110
// update bar x position
111
window.addEventListener("mousemove",follow,false);
112
 
113
var update = function (modifier) {
114
 
115
//update ball position
116
ball.x = ball.x+(ball.speedx*modifier);
117
ball.y= ball.y+(ball.speedy*modifier);
118
 
119
// collision ball
120
if (collision == true){
121
if (ball2.a > 0){ball2.width = ball2.width+1000*modifier;
122
ball2.height=ball2.height+1000*modifier;
123
ball2.x = ball.x;
124
ball2.y = ball.y;
125
ball2.a = ball2.a - 2*modifier;
126
 
127
}else{
128
collision = false;
129
resetball2();
130
}
131
}
132
 
133
// Is ball touching top?
134
if (ball.y <= (0) && ball.speedy < 0) {
135
  
136
  //change direction
137
  ball.speedy = ball.speedy * -1;
138
 
139
}
140
 
141
// Is ball touching left
142
if (ball.x <= (0) && ball.speedx < (0)){
143
  ball.speedx = ball.speedx * -1;
144
}
145
 
146
// Is ball touching right
147
if (ball.x >= (canvas.width-ball.width) && ball.speedx > (0)){
148
  ball.speedx = ball.speedx * -1;
149
}
150
 
151
// Is ball touching bar?
152
if (
153
  ball.x+ball.width >= (bar.x)
154
  && ball.x <= (bar.x+bar.width)
155
  && ball.y+ball.height >= (bar.y)
156
  && ball.speedy > 0
157
) {
158
  // reset sound and play
159
  snd.currentTime = 0;
160
  snd.play();
161
  
162
  // update score
163
  ++score;
164
  if (score > highscore){highscore = score;}
165
  
166
  // increase speed
167
  // boost X if ball hits corner of bar
168
  if(ball.x+ball.width <= (bar.x+ball.width*2)){
169
   
170
    // define flick size
171
    fl = 10+(ball.width*2-((ball.x+ball.width)-bar.x))*5;
172
    
173
    // always flick ball left
174
    if(ball.speedx < 0){ball.speedx = ball.speedx-fl;}
175
    if(ball.speedx > 0){ball.speedx = ball.speedx*(-1)-fl;}
176
  }else if(ball.x >= (bar.x+bar.width-ball.width*2)){
177
  
178
    // define flick size
179
    fr = 10+(ball.width*2-((ball.x+ball.width)-(bar.x+bar.width)))*5;
180
  
181
    // always flick ball right
182
    if(ball.speedx < 0){ball.speedx = ball.speedx*(-1)+fr;}
183
    if(ball.speedx > 0){ball.speedx = ball.speedx+fr;}
184
  }else{
185
    // Randomize x speed on central hit ((-20) to 20)
186
    ball.speedx = ball.speedx + ((Math.random()*40)-20);    
187
  }
188
  
189
  // update Y speed
190
  ball.speedy = ball.speedy +20;
191
  
192
  //change y direction of ball
193
  ball.speedy = ball.speedy * -1;
194
  
195
  //set collision true
196
  collision=true;
197
  
198
  //reset / initialize ball2
199
  resetball2();
200
  //set color
201
  bar.r = ball2.r;
202
  bar.g = ball2.g;
203
  bar.b = ball2.b;
204
  
205
  // set background color
206
  document.body.style.background = "rgb("+bar.r+","+bar.g+","+bar.b+")";
207
}
208
 
209
// Is ball touching bottom?
210
if (ball.y >= (canvas.height-ball.height) && ball.speedy > 0) {
211
  reset();
212
}
213
 
214
 
215
 
216
};
217
 
218
// Draw everything
219
var render = function () {
220
 
221
// set dark grey bg
222
ctx.fillStyle   = '#262626';
223
ctx.fillRect(0,0,canvas.width,canvas.height);
224
 
225
// set logo
226
ctx.drawImage(logo,canvas.width/2-logo.width/2,canvas.height/2-logo.height/2);
227
 
228
// draw ball2 (collision effect)
229
ctx.beginPath();
230
ctx.fillStyle   = "rgba("+ball2.r+","+ball2.g+","+ball2.b+","+ball2.a+")";
231
//ctx.fillRect(ball2.x,ball2.y,ball2.width,ball2.height);
232
ctx.arc(ball2.x+ball.width,bar.y,ball2.width,ball2.height, Math.PI*2, true);
233
ctx.fill();
234
ctx.closePath();
235
 
236
// draw ball 
237
ctx.fillStyle   = "rgb("+bar.r+","+bar.g+","+bar.b+")";
238
ctx.fillRect(ball.x,ball.y,ball.width,ball.height);
239
 
240
// draw bar
241
ctx.fillStyle   = "rgb("+bar.r+","+bar.g+","+bar.b+")";
242
ctx.fillRect(bar.x,bar.y,bar.width,bar.height);
243
 
244
// Score
245
ctx.fillStyle = "rgb(250, 250, 250)";
246
ctx.font = "12px Helvetica";
247
ctx.textAlign = "right";
248
ctx.textBaseline = "top";
249
ctx.fillText("score: " + score, canvas.width-10, 23);
250
 
251
// HighScore
252
ctx.fillStyle = "rgb(250, 250, 250)";
253
ctx.font = "bold 12px Helvetica";
254
ctx.textAlign = "right";
255
ctx.textBaseline = "top";
256
ctx.fillText("best: " + highscore, canvas.width-10, 10);
257
 
258
};
259
 
260
var main = function () {
261
var now = Date.now();
262
var delta = now - then;
263
 
264
update(delta / 1000);
265
render();
266
 
267
then = now;
268
};
269
 
270
reset();
271
var then = Date.now();
272
setInterval(main, 1);
 

Color Pong Game

CSSDeck G+