/minild29

To get this branch, use:
bzr branch http://9ix.org/bzr/minild29

« back to all changes in this revision

Viewing changes to Dark.cpp

  • Committer: Josh C
  • Date: 2011-09-18 04:39:18 UTC
  • Revision ID: josh@9ix.org-20110918043918-eb8i96g094zxhn5q
ping!

Show diffs side-by-side

added added

removed removed

Lines of Context:
94
94
  Creature::Creature() : Entity(),
95
95
                         FRICTION(800),
96
96
                         MAXSPEED(80.0f),
97
 
                         ACCELERATION(1200),
98
 
                         STALKSPEED(5.0f),
99
 
                         HUNTSPEED(80.0f)
 
97
                         ACCELERATION(1200)                      
100
98
  {
101
99
    sprite = new SpriteAnimation("creature.png", FILTER_NONE, 64, 64);
102
100
    sprite->Add("idle", 0, 0, 0.35f);
110
108
 
111
109
    skitter1 = Audio::NewDeck(Assets::RequestAudio("skitter1.ogg"));
112
110
    skitter1->SetLoops(0); //loop indefinitely
 
111
 
113
112
    alert = Assets::RequestAudio("alert.ogg");
114
 
    stalk = Assets::RequestAudio("stalk.ogg");
115
113
 
116
114
    velocity = Vector2::Random() * MAXSPEED;
117
115
 
167
165
        
168
166
        // if we've been listening past the grace period and hear
169
167
        // something, switch state again
170
 
        // We hear the player at DOUBLE noisiness distance, cuz WE'RE LISNING!
171
 
        Player *player = ((DarkScene *)scene)->player;
172
 
        if ( aiTime > 1.0f && 
173
 
             (player->position - position).GetSquaredMagnitude() < 
174
 
             pow(player->noisiness * 2, 2) )
175
 
          {
176
 
            state = "stalk";
177
 
            stalk->Play();
178
 
            Ping::NewPing(position, 8.0f, 32.0f, 0.15f);
179
 
            direction = (player->position - position).GetNormalized() * STALKSPEED;
180
 
            aiTime = 0.0f;
181
 
            noiseTime = 0.0f;
182
 
          }
183
168
 
184
169
        // if we've been listening a long time, switch back to idle
185
170
        if (aiTime > 5.0f) {
186
171
          //printf("end alert\n");
187
172
          state = "idle";
188
 
          aiTime = 0.0f;
189
173
        }
190
174
      }
191
 
    else if (state == "stalk")
192
 
      {
193
 
        aiTime += Monocle::deltaTime;
194
 
        noiseTime += Monocle::deltaTime;
195
 
 
196
 
        // Go to HUNT if:
197
 
        // * it's been >1s & we hear the player
198
 
        // * we collide with the player
199
 
        Player *player = ((DarkScene *)scene)->player;
200
 
        if ((aiTime > 1.0f &&  
201
 
             (player->position - position).GetSquaredMagnitude() < 
202
 
             pow(player->noisiness, 2) )
203
 
            || Collide("player")
204
 
            )
205
 
          {
206
 
            state == "hunt";
207
 
            direction = (player->position - position).GetNormalized() * HUNTSPEED;
208
 
            // Play hunt noise (REEET!)
209
 
 
210
 
          }
211
 
          
212
 
          
213
 
        //after 6 or 7 seconds on the noiseTime clock, play sound and ping again
214
 
        // if we hit a wall, call off the search?
215
 
        //we'll want to play that sound again
216
 
        // do others go ALERT if we start stalking?
217
 
        //probably a timeout here too.
218
 
      }
219
175
 
220
176
    velocity += direction * ACCELERATION * Monocle::deltaTime;
221
177
    
331
287
    Level::LoadProject("project.xml");
332
288
    Level::Load("level.xml", this);
333
289
 
334
 
    HideSpawners();
335
 
    Spawn();
336
 
 
337
290
    std::list<Entity*> *walls = GetAllTag("wall");
338
291
    for (std::list<Entity*>::iterator i = walls->begin(); i != walls->end(); ++i)
339
292
      {
342
295
        e->SetCollider(new RectangleCollider(s.x * 64, s.y * 64));
343
296
      }
344
297
   
345
 
    Graphics::SetBackgroundColor(Color::green * 0.2f);
346
 
 
347
 
  }
348
 
 
349
 
  void DarkScene::HideSpawners()
350
 
  {
351
 
    std::list<Entity*> *spawners = GetAllTag("spawner");
352
 
    if (spawners == NULL) {printf("NO SPAWNERS!!!\n");}
353
 
    for (std::list<Entity*>::iterator i = spawners->begin(); i != spawners->end(); ++i)
354
 
      (*i)->isVisible = false;
355
 
  }
356
 
 
357
 
  void DarkScene::ShowSpawners()
358
 
  {
359
 
    std::list<Entity*> *spawners = GetAllTag("spawner");
360
 
    for (std::list<Entity*>::iterator i = spawners->begin(); i != spawners->end(); ++i)
361
 
      (*i)->isVisible = true;
362
 
  }
363
 
  
364
 
  void DarkScene::Spawn()
365
 
  {
366
 
    Entity* playersp = GetFirstEntityWithTag("playerspawner");
367
298
    player = new Player();
368
 
    player->position = playersp->position;;
 
299
    player->position = Graphics::GetScreenCenter();
369
300
    Add(player);
370
301
    Add(player->dark);
371
302
 
372
 
    std::list<Entity*> *spawners = GetAllTag("creaturespawner");
373
 
    // Ugh, monocle is double-entering all the tags...
374
 
    spawners->sort();
375
 
    spawners->unique();
376
 
    for (std::list<Entity*>::iterator i = spawners->begin(); i != spawners->end(); ++i)
377
 
      {
378
 
        Creature *creature = new Creature();
379
 
        creature->position = (*i)->position;
380
 
        Add(creature);
381
 
      }
 
303
    Creature *creature = new Creature;
 
304
    creature->position = Graphics::GetScreenCenter();
 
305
    Add(creature);
 
306
 
 
307
    Creature *creature2 = new Creature;
 
308
    creature2->position = Graphics::GetScreenCenter();
 
309
    Add(creature2);
 
310
 
 
311
    Graphics::SetBackgroundColor(Color::green * 0.2f);
 
312
 
382
313
  }
383
314
 
384
315
  void DarkScene::Update()
409
340
            
410
341
            if (isPaused) {
411
342
              player->dark->isVisible = false;
412
 
              ShowSpawners();
413
343
              levelEditor->Enable();
414
344
            } else {
415
 
              HideSpawners();
416
345
              levelEditor->Disable();
417
346
              player->dark->isVisible = true;
418
347
            }