/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 16:59:41 UTC
  • Revision ID: josh@9ix.org-20110918165941-waswg2xidvf0v04x
player and creature spawners in level editor

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)                      
 
97
                         ACCELERATION(1200),
 
98
                         STALKSPEED(5.0f),
 
99
                         HUNTSPEED(80.0f)
98
100
  {
99
101
    sprite = new SpriteAnimation("creature.png", FILTER_NONE, 64, 64);
100
102
    sprite->Add("idle", 0, 0, 0.35f);
108
110
 
109
111
    skitter1 = Audio::NewDeck(Assets::RequestAudio("skitter1.ogg"));
110
112
    skitter1->SetLoops(0); //loop indefinitely
111
 
 
112
113
    alert = Assets::RequestAudio("alert.ogg");
 
114
    stalk = Assets::RequestAudio("stalk.ogg");
113
115
 
114
116
    velocity = Vector2::Random() * MAXSPEED;
115
117
 
165
167
        
166
168
        // if we've been listening past the grace period and hear
167
169
        // 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
          }
168
183
 
169
184
        // if we've been listening a long time, switch back to idle
170
185
        if (aiTime > 5.0f) {
171
186
          //printf("end alert\n");
172
187
          state = "idle";
 
188
          aiTime = 0.0f;
173
189
        }
174
190
      }
 
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
      }
175
219
 
176
220
    velocity += direction * ACCELERATION * Monocle::deltaTime;
177
221
    
287
331
    Level::LoadProject("project.xml");
288
332
    Level::Load("level.xml", this);
289
333
 
 
334
    HideSpawners();
 
335
    Spawn();
 
336
 
290
337
    std::list<Entity*> *walls = GetAllTag("wall");
291
338
    for (std::list<Entity*>::iterator i = walls->begin(); i != walls->end(); ++i)
292
339
      {
295
342
        e->SetCollider(new RectangleCollider(s.x * 64, s.y * 64));
296
343
      }
297
344
   
 
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");
298
367
    player = new Player();
299
 
    player->position = Graphics::GetScreenCenter();
 
368
    player->position = playersp->position;;
300
369
    Add(player);
301
370
    Add(player->dark);
302
371
 
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
 
 
 
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
      }
313
382
  }
314
383
 
315
384
  void DarkScene::Update()
340
409
            
341
410
            if (isPaused) {
342
411
              player->dark->isVisible = false;
 
412
              ShowSpawners();
343
413
              levelEditor->Enable();
344
414
            } else {
 
415
              HideSpawners();
345
416
              levelEditor->Disable();
346
417
              player->dark->isVisible = true;
347
418
            }