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 |
||
9
by Josh C
creatures move less, make everything smaller |
112 |
velocity = Vector2::Random() * MAXSPEED; |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
113 |
|
114 |
//set aiTime to random so creatures tick at different times |
|
6
by Josh C
skittering blue square |
115 |
aiTime= (float(rand()) / float(RAND_MAX)) * 1.0f; |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
116 |
} |
117 |
||
118 |
void Creature::Update() |
|
119 |
{ |
|
120 |
Entity::Update(); |
|
121 |
||
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
122 |
if (state == "idle" || state == "wander") |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
123 |
{ |
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
124 |
aiTime += Monocle::deltaTime; |
125 |
if (aiTime > 1.0f) |
|
126 |
{ |
|
127 |
switch (rand() % 3) |
|
128 |
{ |
|
129 |
case 0: // idle |
|
130 |
//printf("idle\n"); |
|
131 |
direction = Vector2::zero; |
|
132 |
state = "idle"; |
|
133 |
break; |
|
134 |
case 1: // move |
|
135 |
if (state != "wander") { |
|
136 |
//printf("wander\n"); |
|
137 |
direction = Vector2::Random(); |
|
138 |
state = "wander"; |
|
139 |
break; |
|
140 |
} |
|
141 |
} |
|
142 |
||
143 |
aiTime = 0.0f; |
|
144 |
} |
|
145 |
||
146 |
Player *player = ((DarkScene *)scene)->player; |
|
147 |
if ( (player->position - position).GetSquaredMagnitude() < |
|
148 |
pow(player->noisiness, 2) ) |
|
149 |
{ |
|
150 |
state = "alert"; |
|
151 |
// TODO: Play startled noise |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
152 |
direction = Vector2::zero; |
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
153 |
// TODO: Play pulse animation (yellow?) |
154 |
aiTime = 0.0f; // diff variable? stateTime? |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
155 |
} |
16
by Josh C
track palyer noisiness, beginnings of "alert" state for creatures |
156 |
} // if idle or wander |
157 |
else if (state == "alert") |
|
158 |
{ |
|
159 |
aiTime += Monocle::deltaTime; |
|
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 we've been listening past the grace period and hear |
162 |
// something, switch state again |
|
163 |
||
164 |
// if we've been listening a long time, switch back to idle |
|
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 |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
167 |
velocity += direction * ACCELERATION * Monocle::deltaTime; |
168 |
||
169 |
velocity.x = APPROACH(velocity.x, 0, FRICTION * Monocle::deltaTime); |
|
170 |
velocity.y = APPROACH(velocity.y, 0, FRICTION * Monocle::deltaTime); |
|
171 |
||
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
172 |
if (velocity.GetSquaredMagnitude() > pow(MAXSPEED, 2)) |
173 |
velocity = velocity.GetNormalized() * MAXSPEED; |
|
174 |
||
6
by Josh C
skittering blue square |
175 |
bool xcol = false; |
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
176 |
bool ycol = false; |
177 |
||
178 |
position.x += velocity.x * Monocle::deltaTime; |
|
179 |
while (Collide("Solid")) |
|
180 |
{ |
|
181 |
xcol = true; |
|
182 |
if (velocity.x == 0) { break; } |
|
183 |
//printf("collision1\n"); |
|
184 |
position.x -= SIGN(velocity.x, 0.1); |
|
185 |
} |
|
186 |
if (xcol) {velocity.x = 0;} |
|
187 |
||
188 |
position.y += velocity.y * Monocle::deltaTime; |
|
189 |
while (Collide("Solid")) |
|
190 |
{ |
|
191 |
ycol = true; |
|
192 |
if (velocity.y == 0) { break; } |
|
193 |
//printf("collision2\n"); |
|
194 |
position.y -= SIGN(velocity.y, 0.1); |
|
195 |
} |
|
196 |
if (ycol) {velocity.y = 0;} |
|
6
by Josh C
skittering blue square |
197 |
|
7
by Josh C
footsteps |
198 |
if (velocity.GetSquaredMagnitude() > 20) |
8
by Josh C
harder to see creatures |
199 |
{ |
15
by Josh C
make maxspeed work. footstep volume has to do with speed. skitter |
200 |
Vector2 distance = ((DarkScene *)scene)->player->position - position; |
201 |
// at distance 0, vol should be 1.0. at 800, it should be 0. |
|
202 |
float vol = (distance.GetMagnitude() / -800.0f) + 1.0f; |
|
203 |
skitter1->SetVolume(vol); |
|
8
by Josh C
harder to see creatures |
204 |
skitter1->Play(); |
205 |
sprite->Play("move"); |
|
206 |
} |
|
6
by Josh C
skittering blue square |
207 |
else |
8
by Josh C
harder to see creatures |
208 |
{ |
209 |
skitter1->Pause(); //Stop()? |
|
210 |
sprite->Play("idle"); |
|
211 |
} |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
212 |
} |
213 |
||
1
by Josh C
initial commit |
214 |
// Scene |
215 |
||
216 |
DarkScene::DarkScene() : Scene() |
|
217 |
{ |
|
218 |
} |
|
219 |
||
220 |
void DarkScene::Begin() |
|
221 |
{ |
|
222 |
Scene::Begin(); |
|
223 |
||
224 |
Graphics::Set2D(1024, 768); |
|
225 |
||
226 |
Text *inst2 = new Text("Press ESC to quit"); |
|
227 |
inst2->position = Vector2(-492, -354); // 20px h, 30px v from U-L corner |
|
228 |
Add(inst2); |
|
229 |
||
230 |
Input::DefineMaskKey("left", KEY_LEFT); |
|
231 |
Input::DefineMaskKey("right", KEY_RIGHT); |
|
232 |
Input::DefineMaskKey("up", KEY_UP); |
|
233 |
Input::DefineMaskKey("down", KEY_DOWN); |
|
234 |
||
235 |
Input::DefineMaskKey("up", KEY_W); |
|
236 |
Input::DefineMaskKey("left", KEY_A); |
|
237 |
Input::DefineMaskKey("down", KEY_S); |
|
238 |
Input::DefineMaskKey("right", KEY_D); |
|
239 |
||
240 |
// level editor |
|
241 |
Add( levelEditor = new LevelEditor() ); |
|
242 |
levelEditor->Disable(); |
|
243 |
||
244 |
// load level from files |
|
245 |
Level::LoadProject("project.xml"); |
|
246 |
Level::Load("level.xml", this); |
|
4
by Josh C
invisible walls and code to bump into them |
247 |
|
13
by Josh C
visible walls |
248 |
std::list<Entity*> *walls = GetAllTag("wall"); |
249 |
for (std::list<Entity*>::iterator i = walls->begin(); i != walls->end(); ++i) |
|
4
by Josh C
invisible walls and code to bump into them |
250 |
{ |
251 |
Entity *e = (*i); |
|
252 |
Vector2 s = e->scale; |
|
253 |
e->SetCollider(new RectangleCollider(s.x * 64, s.y * 64)); |
|
254 |
} |
|
1
by Josh C
initial commit |
255 |
|
11
by Josh C
disappear darkness mask in editor mode |
256 |
player = new Player(); |
1
by Josh C
initial commit |
257 |
player->position = Graphics::GetScreenCenter(); |
258 |
Add(player); |
|
10
by Josh C
"light" in the dark |
259 |
Add(player->dark); |
1
by Josh C
initial commit |
260 |
|
5
by Josh C
added a "creature" moving around w/ the same dynamics as you do |
261 |
Creature *creature = new Creature; |
262 |
creature->position = Graphics::GetScreenCenter(); |
|
263 |
Add(creature); |
|
264 |
||
7
by Josh C
footsteps |
265 |
Creature *creature2 = new Creature; |
266 |
creature2->position = Graphics::GetScreenCenter(); |
|
267 |
Add(creature2); |
|
268 |
||
10
by Josh C
"light" in the dark |
269 |
Graphics::SetBackgroundColor(Color::green * 0.2f); |
1
by Josh C
initial commit |
270 |
|
271 |
} |
|
272 |
||
273 |
void DarkScene::Update() |
|
274 |
{ |
|
275 |
Scene::Update(); |
|
276 |
||
277 |
if (Input::IsKeyPressed(KEY_ESCAPE)) |
|
278 |
Game::Quit(); |
|
279 |
||
280 |
if (isPaused) |
|
281 |
{ |
|
282 |
if (Input::IsKeyPressed(KEY_S) && Input::IsKeyHeld(KEY_LCTRL)) |
|
283 |
Level::Save(); |
|
284 |
||
285 |
if (Input::IsKeyPressed(KEY_A)) |
|
286 |
Scene::GetCamera()->position.x -= 600; |
|
287 |
||
288 |
if (Input::IsKeyPressed(KEY_D)) |
|
289 |
Scene::GetCamera()->position.x += 600; |
|
290 |
} |
|
291 |
||
292 |
if (Input::IsKeyPressed(KEY_TAB)) |
|
293 |
{ |
|
294 |
// if we're not doing anything in the levelEditor... |
|
295 |
if (levelEditor->GetState() == FTES_NONE) |
|
296 |
{ |
|
297 |
isPaused = !isPaused; |
|
298 |
||
11
by Josh C
disappear darkness mask in editor mode |
299 |
if (isPaused) { |
12
by Josh C
drastically less hacky way to hide the darkness |
300 |
player->dark->isVisible = false; |
1
by Josh C
initial commit |
301 |
levelEditor->Enable(); |
11
by Josh C
disappear darkness mask in editor mode |
302 |
} else { |
1
by Josh C
initial commit |
303 |
levelEditor->Disable(); |
12
by Josh C
drastically less hacky way to hide the darkness |
304 |
player->dark->isVisible = true; |
11
by Josh C
disappear darkness mask in editor mode |
305 |
} |
1
by Josh C
initial commit |
306 |
} |
307 |
} |
|
308 |
||
309 |
}// DarkScene::Update |
|
310 |
||
311 |
Text::Text(const std::string& text, FontAsset* font) |
|
312 |
: Entity(), text(text) |
|
313 |
{ |
|
314 |
if (font == NULL) |
|
315 |
this->font = Assets::RequestFont("LiberationSans-Regular.ttf", 18.0f); |
|
316 |
else |
|
317 |
this->font = font; |
|
11
by Josh C
disappear darkness mask in editor mode |
318 |
|
319 |
SetLayer(-2); |
|
1
by Josh C
initial commit |
320 |
} |
321 |
||
322 |
void Text::Render() |
|
323 |
{ |
|
324 |
Graphics::PushMatrix(); |
|
325 |
||
326 |
// place text directly relative to camera |
|
327 |
Graphics::Translate(scene->GetCamera()->position + position); |
|
328 |
||
329 |
Graphics::SetBlend(BLEND_ALPHA); |
|
330 |
Graphics::SetColor(Color::white); |
|
331 |
Graphics::BindFont(font); |
|
332 |
||
333 |
Graphics::RenderText(*font, text, 0, 0); |
|
334 |
Graphics::PopMatrix(); |
|
335 |
} |
|
336 |
||
337 |
} |