-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgame.js
109 lines (92 loc) · 3.05 KB
/
game.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
var sprites = {
ship: { sx: 0, sy: 0, w: 18, h: 35, frames: 3 }
};
var playGame = function() {
//Game.setBoard(3, new TitleScreen("Alien Invasion", "Game started..."));
Game.setBoard(3, new PlayerShip());
}
var startGame = function () {
//SpriteSheet.draw(Game.ctx,"ship",100,100,1);
Game.setBoard(0,new Starfield(20,0.4,100,true))
Game.setBoard(1,new Starfield(50,0.6,100))
Game.setBoard(2,new Starfield(100,1.0,50));
Game.setBoard(3,new TitleScreen("Alien Invasion", "Hit tab to start!", playGame));
}
window.addEventListener('load', function() {
Game.initialize("game", sprites, startGame);
});
// Star field
var Starfield = function(speed, opacity, numOfStars, clear) {
var stars = document.createElement("canvas");
stars.height = Game.height;
stars.width = Game.width;
var starsCtx = stars.getContext("2d");
var offset = 0;
// Clear the context
if (clear) {
starsCtx.fillStyle = "#000";
starsCtx.fillRect(0, 0, stars.width, stars.height);
}
// Draw the stars
starsCtx.fillStyle = "#fff";
starsCtx.globalAlpha = opacity;
for(var i=0; i< numOfStars; i++) {
starsCtx.fillRect(Math.floor(Math.random() * stars.width),
Math.floor(Math.random() * stars.height),
2, 2);
}
// Draw the starfield
this.draw = function(ctx) {
var intOffset = Math.floor(offset);
var remaining = stars.height - intOffset;
// Draw the top half
if (intOffset > 0) {
ctx.drawImage(stars,
0, remaining,
stars.width, intOffset,
0, 0,
stars.width, intOffset);
}
// Draw the bottom half
if (remaining) {
ctx.drawImage(stars,
0, 0,
stars.width, remaining,
0, intOffset,
stars.width, remaining);
}
}
// Scroll the starfield
this.step = function(dt) {
offset += dt * speed;
offse = offset % stars.height;
}
}
var PlayerShip = function() {
this.w = SpriteSheet.map['ship'].w;
this.h = SpriteSheet.map['ship'].h;
this.x = Game.width/2 - this.w/2;
this.y = Game.height - 10 - this.h;
this.vx = 0;
this.maxVel = 200;
this.step = function(dt) {
// the direction
if(Game.keys['left']) {
this.vx = -this.maxVel;
} else if(Game.keys['right']) {
this.vx = this.maxVel;
} else {
this.vx = 0;
}
// Update the x position
this.x += dt * this.vx;
// Make sure that we are still within boundaries
if (this.x < 0)
this.x = 0;
else if (this.x > Game.width - this.w)
this.x = Game.width - this.w;
}
this.draw = function(ctx) {
SpriteSheet.draw(ctx, 'ship', this.x, this.y, 1);
}
}