bzr branch
http://9ix.org/bzr/minild29
1
by Josh C
initial commit |
1 |
#include "Dark.h" |
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
2 |
#include <cmath> |
1
by Josh C
initial commit |
3 |
|
4 |
namespace Dark |
|
5 |
{ |
|
6 |
Player::Player() : Entity(), |
|
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
7 |
FRICTION(150), |
8 |
MAXSPEED(150.0f), |
|
9 |
ACCELERATION(300) |
|
1
by Josh C
initial commit |
10 |
{ |
11 |
sprite = new SpriteAnimation("player.png", FILTER_NONE, 64, 64); |
|
12 |
sprite->Add("idle", 0, 0, 0.35f); |
|
13 |
sprite->Play("idle"); |
|
14 |
SetGraphic(sprite); |
|
9
by Josh C
creatures move less, make everything smaller |
15 |
scale = Vector2(0.25, 0.25); |
1
by Josh C
initial commit |
16 |
|
17 |
AddTag("player"); |
|
7
by Josh C
footsteps |
18 |
|
19 |
footsteps = Audio::NewDeck(Assets::RequestAudio("footsteps.ogg")); |
|
20 |
footsteps->SetLoops(0); //loop indefinitely |
|
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
21 |
footsteps->SetVolume(0); |
22 |
footsteps->Play(); |
|
1
by Josh C
initial commit |
23 |
|
9
by Josh C
creatures move less, make everything smaller |
24 |
SetCollider(new RectangleCollider(16, 16)); |
10
by Josh C
"light" in the dark |
25 |
|
26 |
dark = new Entity(); |
|
27 |
dark->SetGraphic(new Sprite("dark.png", FILTER_NONE, 2048, 1536)); //alpha? |
|
1
by Josh C
initial commit |
28 |
} |
29 |
||
30 |
void Player::Update() |
|
31 |
{ |
|
32 |
Entity::Update(); |
|
33 |
||
3
by Josh C
square moving around the screen |
34 |
if (Input::IsKeyMaskHeld("left")) |
35 |
{ |
|
36 |
velocity.x -= ACCELERATION * Monocle::deltaTime; |
|
37 |
} |
|
38 |
if (Input::IsKeyMaskHeld("right")) |
|
39 |
{ |
|
40 |
velocity.x += ACCELERATION * Monocle::deltaTime; |
|
41 |
} |
|
42 |
if (Input::IsKeyMaskHeld("up")) |
|
43 |
{ |
|
44 |
velocity.y -= ACCELERATION * Monocle::deltaTime; |
|
45 |
} |
|
46 |
if (Input::IsKeyMaskHeld("down")) |
|
47 |
{ |
|
48 |
velocity.y += ACCELERATION * Monocle::deltaTime; |
|
49 |
} |
|
50 |
||
51 |
// velocity will approach 0 in steps of FRICTION * dt |
|
52 |
velocity.x = APPROACH(velocity.x, 0, FRICTION * Monocle::deltaTime); |
|
53 |
velocity.y = APPROACH(velocity.y, 0, FRICTION * Monocle::deltaTime); |
|
54 |
||
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
55 |
if (velocity.GetSquaredMagnitude() > pow(MAXSPEED, 2)) |
56 |
velocity = velocity.GetNormalized() * MAXSPEED; |
|
57 |
||
4
by Josh C
invisible walls and code to bump into them |
58 |
bool xcol = false; |
59 |
bool ycol = false; |
|
60 |
||
61 |
position.x += velocity.x * Monocle::deltaTime; |
|
62 |
while (Collide("Solid")) |
|
63 |
{ |
|
64 |
xcol = true; |
|
65 |
if (velocity.x == 0) { break; } |
|
66 |
//printf("collision1\n"); |
|
67 |
position.x -= SIGN(velocity.x, 0.1); |
|
68 |
} |
|
69 |
if (xcol) {velocity.x = 0;} |
|
70 |
||
71 |
position.y += velocity.y * Monocle::deltaTime; |
|
72 |
while (Collide("Solid")) |
|
73 |
{ |
|
74 |
ycol = true; |
|
75 |
if (velocity.y == 0) { break; } |
|
76 |
//printf("collision2\n"); |
|
77 |
position.y -= SIGN(velocity.y, 0.1); |
|
78 |
} |
|
79 |
if (ycol) {velocity.y = 0;} |
|
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
80 |
|
81 |
float magnitude = velocity.GetMagnitude(); |
|
82 |
||
83 |
footsteps->SetVolume(magnitude / MAXSPEED); |
|
84 |
||
85 |
// How far away can they hear your footsteps? |
|
86 |
// The circle is diameter 300 at MAXSPEED, 32 (2x your size) at 0 speed |
|
87 |
noisiness = ((magnitude / MAXSPEED *(300-32)) + 32) /2; |
|
3
by Josh C
square moving around the screen |
88 |
|
10
by Josh C
"light" in the dark |
89 |
dark->position = position; |
90 |
||
1
by Josh C
initial commit |
91 |
//Scene::GetCamera()->position = position; |
92 |
} |
|
93 |
||
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
94 |
Creature::Creature() : Entity(), |
6
by Josh C
skittering blue square |
95 |
FRICTION(800), |
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
96 |
MAXSPEED(80.0f), |
6
by Josh C
skittering blue square |
97 |
ACCELERATION(1200) |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
98 |
{ |
99 |
sprite = new SpriteAnimation("creature.png", FILTER_NONE, 64, 64); |
|
100 |
sprite->Add("idle", 0, 0, 0.35f); |
|
8
by Josh C
harder to see creatures |
101 |
sprite->Add("move", 1, 2, 4.0f); |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
102 |
sprite->Play("idle"); |
103 |
SetGraphic(sprite); |
|
9
by Josh C
creatures move less, make everything smaller |
104 |
scale = Vector2(0.25, 0.25); |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
105 |
|
106 |
AddTag("creature"); |
|
9
by Josh C
creatures move less, make everything smaller |
107 |
SetCollider(new RectangleCollider(16, 16)); |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
108 |
|
6
by Josh C
skittering blue square |
109 |
skitter1 = Audio::NewDeck(Assets::RequestAudio("skitter1.ogg")); |
110 |
skitter1->SetLoops(0); //loop indefinitely |
|
111 |
||
17
by Josh C
alert noise |
112 |
alert = Assets::RequestAudio("alert.ogg"); |
113 |
||
9
by Josh C
creatures move less, make everything smaller |
114 |
velocity = Vector2::Random() * MAXSPEED; |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
115 |
|
116 |
//set aiTime to random so creatures tick at different times |
|
6
by Josh C
skittering blue square |
117 |
aiTime= (float(rand()) / float(RAND_MAX)) * 1.0f; |
17
by Josh C
alert noise |
118 |
|
119 |
state = "idle"; |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
120 |
} |
121 |
||
122 |
void Creature::Update() |
|
123 |
{ |
|
124 |
Entity::Update(); |
|
125 |
||
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
126 |
if (state == "idle" || state == "wander") |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
127 |
{ |
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
128 |
aiTime += Monocle::deltaTime; |
129 |
if (aiTime > 1.0f) |
|
130 |
{ |
|
131 |
switch (rand() % 3) |
|
132 |
{ |
|
133 |
case 0: // idle |
|
134 |
//printf("idle\n"); |
|
135 |
direction = Vector2::zero; |
|
136 |
state = "idle"; |
|
137 |
break; |
|
138 |
case 1: // move |
|
139 |
if (state != "wander") { |
|
140 |
//printf("wander\n"); |
|
141 |
direction = Vector2::Random(); |
|
142 |
state = "wander"; |
|
143 |
break; |
|
144 |
} |
|
145 |
} |
|
146 |
||
147 |
aiTime = 0.0f; |
|
148 |
} |
|
149 |
||
150 |
Player *player = ((DarkScene *)scene)->player; |
|
151 |
if ( (player->position - position).GetSquaredMagnitude() < |
|
152 |
pow(player->noisiness, 2) ) |
|
153 |
{ |
|
17
by Josh C
alert noise |
154 |
//printf("alert\n"); |
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
155 |
state = "alert"; |
17
by Josh C
alert noise |
156 |
alert->Play(); |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
157 |
direction = Vector2::zero; |
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
158 |
// TODO: Play pulse animation (yellow?) |
159 |
aiTime = 0.0f; // diff variable? stateTime? |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
160 |
} |
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
161 |
} // if idle or wander |
162 |
else if (state == "alert") |
|
163 |
{ |
|
164 |
aiTime += Monocle::deltaTime; |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
165 |
|
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
166 |
// if we've been listening past the grace period and hear |
167 |
// something, switch state again |
|
168 |
||
169 |
// if we've been listening a long time, switch back to idle |
|
17
by Josh C
alert noise |
170 |
if (aiTime > 5.0f) { |
171 |
//printf("end alert\n"); |
|
172 |
state = "idle"; |
|
173 |
} |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
174 |
} |
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
175 |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
176 |
velocity += direction * ACCELERATION * Monocle::deltaTime; |
177 |
||
178 |
velocity.x = APPROACH(velocity.x, 0, FRICTION * Monocle::deltaTime); |
|
179 |
velocity.y = APPROACH(velocity.y, 0, FRICTION * Monocle::deltaTime); |
|
180 |
||
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
181 |
if (velocity.GetSquaredMagnitude() > pow(MAXSPEED, 2)) |
182 |
velocity = velocity.GetNormalized() * MAXSPEED; |
|
183 |
||
6
by Josh C
skittering blue square |
184 |
bool xcol = false; |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
185 |
bool ycol = false; |
186 |
||
187 |
position.x += velocity.x * Monocle::deltaTime; |
|
188 |
while (Collide("Solid")) |
|
189 |
{ |
|
190 |
xcol = true; |
|
191 |
if (velocity.x == 0) { break; } |
|
192 |
//printf("collision1\n"); |
|
193 |
position.x -= SIGN(velocity.x, 0.1); |
|
194 |
} |
|
195 |
if (xcol) {velocity.x = 0;} |
|
196 |
||
197 |
position.y += velocity.y * Monocle::deltaTime; |
|
198 |
while (Collide("Solid")) |
|
199 |
{ |
|
200 |
ycol = true; |
|
201 |
if (velocity.y == 0) { break; } |
|
202 |
//printf("collision2\n"); |
|
203 |
position.y -= SIGN(velocity.y, 0.1); |
|
204 |
} |
|
205 |
if (ycol) {velocity.y = 0;} |
|
6
by Josh C
skittering blue square |
206 |
|
7
by Josh C
footsteps |
207 |
if (velocity.GetSquaredMagnitude() > 20) |
8
by Josh C
harder to see creatures |
208 |
{ |
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
209 |
Vector2 distance = ((DarkScene *)scene)->player->position - position; |
210 |
// at distance 0, vol should be 1.0. at 800, it should be 0. |
|
211 |
float vol = (distance.GetMagnitude() / -800.0f) + 1.0f; |
|
212 |
skitter1->SetVolume(vol); |
|
8
by Josh C
harder to see creatures |
213 |
skitter1->Play(); |
214 |
sprite->Play("move"); |
|
215 |
} |
|
6
by Josh C
skittering blue square |
216 |
else |
8
by Josh C
harder to see creatures |
217 |
{ |
218 |
skitter1->Pause(); //Stop()? |
|
219 |
sprite->Play("idle"); |
|
220 |
} |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
221 |
} |
222 |
||
1
by Josh C
initial commit |
223 |
// Scene |
224 |
||
225 |
DarkScene::DarkScene() : Scene() |
|
226 |
{ |
|
227 |
} |
|
228 |
||
229 |
void DarkScene::Begin() |
|
230 |
{ |
|
231 |
Scene::Begin(); |
|
232 |
||
233 |
Graphics::Set2D(1024, 768); |
|
234 |
||
235 |
Text *inst2 = new Text("Press ESC to quit"); |
|
236 |
inst2->position = Vector2(-492, -354); // 20px h, 30px v from U-L corner |
|
237 |
Add(inst2); |
|
238 |
||
239 |
Input::DefineMaskKey("left", KEY_LEFT); |
|
240 |
Input::DefineMaskKey("right", KEY_RIGHT); |
|
241 |
Input::DefineMaskKey("up", KEY_UP); |
|
242 |
Input::DefineMaskKey("down", KEY_DOWN); |
|
243 |
||
244 |
Input::DefineMaskKey("up", KEY_W); |
|
245 |
Input::DefineMaskKey("left", KEY_A); |
|
246 |
Input::DefineMaskKey("down", KEY_S); |
|
247 |
Input::DefineMaskKey("right", KEY_D); |
|
248 |
||
249 |
// level editor |
|
250 |
Add( levelEditor = new LevelEditor() ); |
|
251 |
levelEditor->Disable(); |
|
252 |
||
253 |
// load level from files |
|
254 |
Level::LoadProject("project.xml"); |
|
255 |
Level::Load("level.xml", this); |
|
4
by Josh C
invisible walls and code to bump into them |
256 |
|
13
by Josh C
visible walls |
257 |
std::list<Entity*> *walls = GetAllTag("wall"); |
258 |
for (std::list<Entity*>::iterator i = walls->begin(); i != walls->end(); ++i) |
|
4
by Josh C
invisible walls and code to bump into them |
259 |
{ |
260 |
Entity *e = (*i); |
|
261 |
Vector2 s = e->scale; |
|
262 |
e->SetCollider(new RectangleCollider(s.x * 64, s.y * 64)); |
|
263 |
} |
|
1
by Josh C
initial commit |
264 |
|
11
by Josh C
disappear darkness mask in editor mode |
265 |
player = new Player(); |
1
by Josh C
initial commit |
266 |
player->position = Graphics::GetScreenCenter(); |
267 |
Add(player); |
|
10
by Josh C
"light" in the dark |
268 |
Add(player->dark); |
1
by Josh C
initial commit |
269 |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
270 |
Creature *creature = new Creature; |
271 |
creature->position = Graphics::GetScreenCenter(); |
|
272 |
Add(creature); |
|
273 |
||
7
by Josh C
footsteps |
274 |
Creature *creature2 = new Creature; |
275 |
creature2->position = Graphics::GetScreenCenter(); |
|
276 |
Add(creature2); |
|
277 |
||
10
by Josh C
"light" in the dark |
278 |
Graphics::SetBackgroundColor(Color::green * 0.2f); |
1
by Josh C
initial commit |
279 |
|
280 |
} |
|
281 |
||
282 |
void DarkScene::Update() |
|
283 |
{ |
|
284 |
Scene::Update(); |
|
285 |
||
286 |
if (Input::IsKeyPressed(KEY_ESCAPE)) |
|
287 |
Game::Quit(); |
|
288 |
||
289 |
if (isPaused) |
|
290 |
{ |
|
291 |
if (Input::IsKeyPressed(KEY_S) && Input::IsKeyHeld(KEY_LCTRL)) |
|
292 |
Level::Save(); |
|
293 |
||
294 |
if (Input::IsKeyPressed(KEY_A)) |
|
295 |
Scene::GetCamera()->position.x -= 600; |
|
296 |
||
297 |
if (Input::IsKeyPressed(KEY_D)) |
|
298 |
Scene::GetCamera()->position.x += 600; |
|
299 |
} |
|
300 |
||
301 |
if (Input::IsKeyPressed(KEY_TAB)) |
|
302 |
{ |
|
303 |
// if we're not doing anything in the levelEditor... |
|
304 |
if (levelEditor->GetState() == FTES_NONE) |
|
305 |
{ |
|
306 |
isPaused = !isPaused; |
|
307 |
||
11
by Josh C
disappear darkness mask in editor mode |
308 |
if (isPaused) { |
12
by Josh C
drastically less hacky way to hide the darkness |
309 |
player->dark->isVisible = false; |
1
by Josh C
initial commit |
310 |
levelEditor->Enable(); |
11
by Josh C
disappear darkness mask in editor mode |
311 |
} else { |
1
by Josh C
initial commit |
312 |
levelEditor->Disable(); |
12
by Josh C
drastically less hacky way to hide the darkness |
313 |
player->dark->isVisible = true; |
11
by Josh C
disappear darkness mask in editor mode |
314 |
} |
1
by Josh C
initial commit |
315 |
} |
316 |
} |
|
317 |
||
318 |
}// DarkScene::Update |
|
319 |
||
320 |
Text::Text(const std::string& text, FontAsset* font) |
|
321 |
: Entity(), text(text) |
|
322 |
{ |
|
323 |
if (font == NULL) |
|
324 |
this->font = Assets::RequestFont("LiberationSans-Regular.ttf", 18.0f); |
|
325 |
else |
|
326 |
this->font = font; |
|
11
by Josh C
disappear darkness mask in editor mode |
327 |
|
328 |
SetLayer(-2); |
|
1
by Josh C
initial commit |
329 |
} |
330 |
||
331 |
void Text::Render() |
|
332 |
{ |
|
333 |
Graphics::PushMatrix(); |
|
334 |
||
335 |
// place text directly relative to camera |
|
336 |
Graphics::Translate(scene->GetCamera()->position + position); |
|
337 |
||
338 |
Graphics::SetBlend(BLEND_ALPHA); |
|
339 |
Graphics::SetColor(Color::white); |
|
340 |
Graphics::BindFont(font); |
|
341 |
||
342 |
Graphics::RenderText(*font, text, 0, 0); |
|
343 |
Graphics::PopMatrix(); |
|
344 |
} |
|
345 |
||
346 |
} |