/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 22:31:01 UTC
  • Revision ID: josh@9ix.org-20110918223101-7s86wvx5dkkekhgg
now they chase you (hunt)

Show diffs side-by-side

added added

removed removed

Lines of Context:
108
108
    AddTag("creature");
109
109
    SetCollider(new RectangleCollider(16, 16));
110
110
 
 
111
    alert = Assets::RequestAudio("alert.ogg");
 
112
    freakout = Assets::RequestAudio("freakout.ogg");
111
113
    skitter1 = Audio::NewDeck(Assets::RequestAudio("skitter1.ogg"));
112
114
    skitter1->SetLoops(0); //loop indefinitely
113
 
    alert = Assets::RequestAudio("alert.ogg");
114
115
    sniff = Audio::NewDeck(Assets::RequestAudio("sniff.ogg"));
115
116
    sniff->SetLoops(0);
116
117
 
202
203
            || Collide("player")
203
204
            )
204
205
          {
205
 
            //state = "hunt";
 
206
            state = "hunt";
206
207
            direction = (player->position - position).GetNormalized();
207
 
            //maxspeed = DEFAULT_MAXSPEED;
208
 
            // Play hunt noise (REEET!)
209
 
            //aiTime = 0.0f;
 
208
            maxspeed = 0; // give them a running start
 
209
            sniff->Stop();
 
210
            freakout->Play();
 
211
            // TODO: big yellow ping
 
212
            aiTime = 0.0f;
 
213
            noiseTime = 0.0f;
210
214
          }
211
215
 
212
216
        // Go back to IDLE if:
213
217
        // * we hit a wall
214
 
        // * we hunt for more than 10-15s
 
218
        // * we stalk for more than 10-15s
215
219
        if ((aiTime > 15.0f) || Collide("wall"))
216
220
          {
217
221
            // play frustrated noise?
222
226
            direction = Vector2::zero;
223
227
          }
224
228
      }
 
229
    else if (state == "hunt")
 
230
      {
 
231
        aiTime += Monocle::deltaTime;
 
232
        noiseTime += Monocle::deltaTime;
 
233
 
 
234
        if ((aiTime > 1.0f) && (maxspeed != DEFAULT_MAXSPEED))
 
235
          maxspeed = DEFAULT_MAXSPEED;
 
236
 
 
237
        // if we hear the player (
 
238
        Player *player = ((DarkScene *)scene)->player;
 
239
        if ( (player->position - position).GetSquaredMagnitude() < 
 
240
             pow(player->noisiness, 2) )
 
241
          {
 
242
            direction = (player->position - position).GetNormalized();
 
243
            aiTime = 0.0f;
 
244
            if (noiseTime > 1.0f) {
 
245
              freakout->Play();
 
246
              // TODO: big yellow ping
 
247
              noiseTime = 0.0f;
 
248
            }
 
249
          }
 
250
 
 
251
        // I guess chill out if it's been a while
 
252
        if (aiTime > 15.0f) {
 
253
            state = "alert";
 
254
            //alert->Play();
 
255
            direction = Vector2::zero;
 
256
            aiTime = 0.0f;
 
257
        }
 
258
 
 
259
        // if we collide with you... game over?
 
260
      }
225
261
 
226
262
    velocity += direction * ACCELERATION * Monocle::deltaTime;
227
263