/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 05:20:04 UTC
  • Revision ID: josh@9ix.org-20110918052004-h8uksv9kzu7vdh0w
beginnings of "stalk" state

Show diffs side-by-side

added added

removed removed

Lines of Context:
93
93
 
94
94
  Creature::Creature() : Entity(),
95
95
                         FRICTION(800),
 
96
                         MAXSPEED(80.0f),
96
97
                         ACCELERATION(1200),
97
 
                         DEFAULT_MAXSPEED(80.0f),
98
 
                         STALKSPEED(20.0f)
 
98
                         STALKSPEED(5.0f)
99
99
  {
100
100
    sprite = new SpriteAnimation("creature.png", FILTER_NONE, 64, 64);
101
101
    sprite->Add("idle", 0, 0, 0.35f);
102
102
    sprite->Add("move", 1, 2, 4.0f);
103
 
    sprite->Add("slowmove", 1, 2, 2.0f);
104
103
    sprite->Play("idle");
105
104
    SetGraphic(sprite);
106
105
    scale = Vector2(0.25, 0.25);
111
110
    skitter1 = Audio::NewDeck(Assets::RequestAudio("skitter1.ogg"));
112
111
    skitter1->SetLoops(0); //loop indefinitely
113
112
    alert = Assets::RequestAudio("alert.ogg");
114
 
    sniff = Audio::NewDeck(Assets::RequestAudio("sniff.ogg"));
115
 
    sniff->SetLoops(0);
 
113
    stalk = Assets::RequestAudio("stalk.ogg");
116
114
 
117
 
    maxspeed = DEFAULT_MAXSPEED;
 
115
    velocity = Vector2::Random() * MAXSPEED;
118
116
 
119
117
    //set aiTime to random so creatures tick at different times
120
118
    aiTime= (float(rand()) / float(RAND_MAX)) * 1.0f;
175
173
             pow(player->noisiness * 2, 2) )
176
174
          {
177
175
            state = "stalk";
 
176
            stalk->Play();
178
177
            Ping::NewPing(position, 8.0f, 32.0f, 0.15f);
179
 
            direction = (player->position - position).GetNormalized();
180
 
            maxspeed = STALKSPEED;
 
178
            direction = (player->position - position).GetNormalized() * STALKSPEED;
181
179
            aiTime = 0.0f;
 
180
            noiseTime = 0.0f;
182
181
          }
183
182
 
184
183
        // if we've been listening a long time, switch back to idle
192
191
      {
193
192
        aiTime += Monocle::deltaTime;
194
193
 
195
 
        // Go to HUNT if:
196
 
        // * it's been >1s & we hear the player
197
 
        // * we collide with the player
198
 
        Player *player = ((DarkScene *)scene)->player;
199
 
        if ((aiTime > 1.0f &&  
200
 
             (player->position - position).GetSquaredMagnitude() < 
201
 
             pow(player->noisiness, 2) )
202
 
            || Collide("player")
203
 
            )
204
 
          {
205
 
            //state = "hunt";
206
 
            direction = (player->position - position).GetNormalized();
207
 
            //maxspeed = DEFAULT_MAXSPEED;
208
 
            // Play hunt noise (REEET!)
209
 
            //aiTime = 0.0f;
210
 
          }
 
194
        // if we hear the player while stalking (normal range), go to HUNT
211
195
 
212
 
        // Go back to IDLE if:
213
 
        // * we hit a wall
214
 
        // * we hunt for more than 10-15s
215
 
        if ((aiTime > 15.0f) || Collide("wall"))
216
 
          {
217
 
            // play frustrated noise?
218
 
            state = "idle";
219
 
            aiTime = 0.0f;
220
 
            sniff->Stop();
221
 
            maxspeed = DEFAULT_MAXSPEED;
222
 
            direction = Vector2::zero;
223
 
          }
 
196
        //after 6 or 7 seconds on the noiseTime clock, play sound and ping again
 
197
        // if we hit a wall, call off the search?
 
198
        //we'll want to play that sound again
 
199
        // do others go ALERT if we start stalking?
 
200
        // and if we collide with the player?
224
201
      }
225
202
 
226
203
    velocity += direction * ACCELERATION * Monocle::deltaTime;
228
205
    velocity.x = APPROACH(velocity.x, 0, FRICTION * Monocle::deltaTime);
229
206
    velocity.y = APPROACH(velocity.y, 0, FRICTION * Monocle::deltaTime);
230
207
 
231
 
    if (velocity.GetSquaredMagnitude() > pow(maxspeed, 2))
232
 
      velocity = velocity.GetNormalized() * maxspeed;
 
208
    if (velocity.GetSquaredMagnitude() > pow(MAXSPEED, 2))
 
209
      velocity = velocity.GetNormalized() * MAXSPEED;
233
210
 
234
211
    bool xcol = false;
235
212
    bool ycol = false;
254
231
      }
255
232
    if (ycol) {velocity.y = 0;}
256
233
 
257
 
    Vector2 distance = ((DarkScene *)scene)->player->position - position;
258
 
    if (state == "stalk")
259
 
      {
260
 
        float vol = (distance.GetMagnitude() / -250.0f) + 1.0f;
261
 
        sniff->SetVolume(vol);
262
 
        sniff->Play();
263
 
        sprite->Play("slowmove");
264
 
      }
265
 
    else if (velocity.GetSquaredMagnitude() > 20)
266
 
      {
 
234
    if (velocity.GetSquaredMagnitude() > 20)
 
235
      {
 
236
        Vector2 distance = ((DarkScene *)scene)->player->position - position;
267
237
        // at distance 0, vol should be 1.0.  at 800, it should be 0.
268
 
        float vol = (distance.GetMagnitude() / -600.0f) + 1.0f;
 
238
        float vol = (distance.GetMagnitude() / -800.0f) + 1.0f;
269
239
        skitter1->SetVolume(vol);
270
240
        skitter1->Play();
271
241
        sprite->Play("move");
344
314
    Level::LoadProject("project.xml");
345
315
    Level::Load("level.xml", this);
346
316
 
347
 
    HideSpawners();
348
 
    Spawn();
349
 
 
350
317
    std::list<Entity*> *walls = GetAllTag("wall");
351
318
    for (std::list<Entity*>::iterator i = walls->begin(); i != walls->end(); ++i)
352
319
      {
355
322
        e->SetCollider(new RectangleCollider(s.x * 64, s.y * 64));
356
323
      }
357
324
   
358
 
    Graphics::SetBackgroundColor(Color::green * 0.2f);
359
 
 
360
 
  }
361
 
 
362
 
  void DarkScene::HideSpawners()
363
 
  {
364
 
    std::list<Entity*> *spawners = GetAllTag("spawner");
365
 
    if (spawners == NULL) {printf("NO SPAWNERS!!!\n");}
366
 
    for (std::list<Entity*>::iterator i = spawners->begin(); i != spawners->end(); ++i)
367
 
      (*i)->isVisible = false;
368
 
  }
369
 
 
370
 
  void DarkScene::ShowSpawners()
371
 
  {
372
 
    std::list<Entity*> *spawners = GetAllTag("spawner");
373
 
    for (std::list<Entity*>::iterator i = spawners->begin(); i != spawners->end(); ++i)
374
 
      (*i)->isVisible = true;
375
 
  }
376
 
  
377
 
  void DarkScene::Spawn()
378
 
  {
379
 
    Entity* playersp = GetFirstEntityWithTag("playerspawner");
380
325
    player = new Player();
381
 
    player->position = playersp->position;;
 
326
    player->position = Graphics::GetScreenCenter();
382
327
    Add(player);
383
328
    Add(player->dark);
384
329
 
385
 
    std::list<Entity*> *spawners = GetAllTag("creaturespawner");
386
 
    // Ugh, monocle is double-entering all the tags...
387
 
    spawners->sort();
388
 
    spawners->unique();
389
 
    for (std::list<Entity*>::iterator i = spawners->begin(); i != spawners->end(); ++i)
390
 
      {
391
 
        Creature *creature = new Creature();
392
 
        creature->position = (*i)->position;
393
 
        Add(creature);
394
 
      }
 
330
    Creature *creature = new Creature;
 
331
    creature->position = Graphics::GetScreenCenter();
 
332
    Add(creature);
 
333
 
 
334
    Creature *creature2 = new Creature;
 
335
    creature2->position = Graphics::GetScreenCenter();
 
336
    Add(creature2);
 
337
 
 
338
    Graphics::SetBackgroundColor(Color::green * 0.2f);
 
339
 
395
340
  }
396
341
 
397
342
  void DarkScene::Update()
422
367
            
423
368
            if (isPaused) {
424
369
              player->dark->isVisible = false;
425
 
              ShowSpawners();
426
370
              levelEditor->Enable();
427
371
            } else {
428
 
              HideSpawners();
429
372
              levelEditor->Disable();
430
373
              player->dark->isVisible = true;
431
374
            }