latest
authorhgn <hgodden00@gmail.com>
Wed, 28 Sep 2022 15:16:26 +0000 (16:16 +0100)
committerhgn <hgodden00@gmail.com>
Wed, 28 Sep 2022 15:16:26 +0000 (16:16 +0100)
16 files changed:
audio.h
player.h
sound_src/ding.ogg [new file with mode: 0644]
sound_src/gate_ambient.ogg [new file with mode: 0644]
sound_src/gate_lap.ogg [new file with mode: 0644]
sound_src/gate_pass.ogg [new file with mode: 0644]
sound_src/revert0.ogg [new file with mode: 0644]
sound_src/revert1.ogg [new file with mode: 0644]
sound_src/revert2.ogg [new file with mode: 0644]
sound_src/revert3.ogg [new file with mode: 0644]
sound_src/revert4.ogg [new file with mode: 0644]
sound_src/snap0.ogg [new file with mode: 0644]
sound_src/snap1.ogg [new file with mode: 0644]
sound_src/snap2.ogg [new file with mode: 0644]
sound_src/snap3.ogg [new file with mode: 0644]
world.h

diff --git a/audio.h b/audio.h
index 60ad27ef431bccbdbe113dbe5ed0cc099d2bc341..a9815861680d4c247b83f8dd8d23a7c4908855fb 100644 (file)
--- a/audio.h
+++ b/audio.h
@@ -10,13 +10,53 @@ static float audio_occlusion_current = 0.0f,
 
 static int   k_audio_debug_soundscape = 0;
 
-
 audio_clip audio_board[] =
 {
-   {.path="sound/skate.ogg", .source_mode=k_audio_source_mono_compressed },
-   {.path="sound/wheel.ogg", .source_mode=k_audio_source_mono_compressed },
-   {.path="sound/slide.ogg", .source_mode=k_audio_source_mono_compressed },
-   {.path="sound/reverb.ogg",.source_mode=k_audio_source_mono_compressed }
+   {.path="sound/skate.ogg", .source_mode=k_audio_source_compressed },
+   {.path="sound/wheel.ogg", .source_mode=k_audio_source_compressed },
+   {.path="sound/slide.ogg", .source_mode=k_audio_source_compressed },
+   {.path="sound/reverb.ogg",.source_mode=k_audio_source_compressed }
+};
+
+audio_clip audio_ding =
+{ .path = "sound/ding.ogg", .source_mode=k_audio_source_compressed };
+
+audio_clip audio_jumps[] = {
+   { .path = "sound/snap0.ogg", .source_mode=k_audio_source_compressed, },
+   { .path = "sound/snap1.ogg", .source_mode=k_audio_source_compressed, },
+   { .path = "sound/snap2.ogg", .source_mode=k_audio_source_compressed, },
+   { .path = "sound/snap3.ogg", .source_mode=k_audio_source_compressed, }
+};
+
+audio_clip audio_lands[] = {
+   { .path = "sound/revert0.ogg", .source_mode=k_audio_source_compressed },
+   { .path = "sound/revert1.ogg", .source_mode=k_audio_source_compressed },
+   { .path = "sound/revert2.ogg", .source_mode=k_audio_source_compressed },
+   { .path = "sound/revert3.ogg", .source_mode=k_audio_source_compressed },
+   { .path = "sound/revert4.ogg", .source_mode=k_audio_source_compressed }
+};
+
+audio_clip audio_ambience[] =
+{
+   {.path="sound/town_generic.ogg", 
+      .source_mode=k_audio_source_compressed }
+};
+
+audio_clip audio_gate_pass = {
+   .path = "sound/gate_pass.ogg", .source_mode=k_audio_source_compressed
+};
+
+audio_clip audio_gate_lap = {
+   .path = "sound/gate_lap.ogg", .source_mode=k_audio_source_compressed
+};
+
+audio_clip audio_gate_ambient = {
+.path = "sound/gate_ambient.ogg", .source_mode=k_audio_source_compressed
+};
+
+audio_player ambient_player =
+{
+   .name = "Ambience"
 };
 
 audio_player audio_player0 =
@@ -39,9 +79,34 @@ audio_player audio_player3 =
    .name = "Player3",
 };
 
+audio_player audio_player_extra =
+{
+   .name = "PlayerInst"
+};
+
+audio_player audio_player_gate =
+{
+   .name = "Gate"
+};
+
 static void audio_init(void)
 {
+   audio_player_init( &audio_player0 );
+   audio_player_init( &audio_player1 );
+   audio_player_init( &audio_player2 );
+   audio_player_init( &audio_player3 );
+   audio_player_init( &audio_player_gate );
+   audio_player_init( &ambient_player );
+   audio_player_init( &audio_player_extra );
+
    audio_clip_loadn( audio_board, vg_list_size(audio_board) );
+   audio_clip_loadn( audio_ambience, vg_list_size(audio_ambience) );
+   audio_clip_loadn( &audio_ding, 1 );
+   audio_clip_loadn( &audio_gate_pass, 1 );
+   audio_clip_loadn( &audio_gate_lap, 1 );
+   audio_clip_loadn( &audio_gate_ambient, 1 );
+   audio_clip_loadn( audio_jumps, vg_list_size(audio_jumps) );
+   audio_clip_loadn( audio_lands, vg_list_size(audio_lands) );
 
    audio_lock();
    u32 flags = AUDIO_FLAG_LOOP|AUDIO_FLAG_SPACIAL_3D;
@@ -49,12 +114,19 @@ static void audio_init(void)
    audio_player_set_flags( &audio_player0, flags );
    audio_player_set_flags( &audio_player1, flags );
    audio_player_set_flags( &audio_player2, flags );
+   audio_player_set_flags( &audio_player_gate, flags );
    audio_player_set_flags( &audio_player3, AUDIO_FLAG_LOOP );
+   audio_player_set_flags( &ambient_player, AUDIO_FLAG_LOOP );
+   audio_player_set_vol( &ambient_player, 1.0f );
+   audio_player_set_vol( &audio_player_gate, 5.0f );
+   audio_player_set_vol( &audio_player_extra, 1.0f );
 
    audio_player_playclip( &audio_player0, &audio_board[0] );
    audio_player_playclip( &audio_player1, &audio_board[1] );
    audio_player_playclip( &audio_player2, &audio_board[2] );
    audio_player_playclip( &audio_player3, &audio_board[3] );
+   audio_player_playclip( &ambient_player, &audio_ambience[0] );
+   audio_player_playclip( &audio_player_gate, &audio_gate_ambient );
 
    audio_unlock();
 
@@ -86,6 +158,9 @@ static void audio_sample_occlusion( v3f origin )
 
    int sample_count = 8;
 
+   int lv = 0;
+   v3f last;
+
    for( int i=0; i<sample_count; i++ )
    {
       v3f dir;
@@ -100,6 +175,11 @@ static void audio_sample_occlusion( v3f origin )
 
          vg_line( origin, contact.pos, 0xff0000ff );
          vg_line_pt3( contact.pos, 0.1f, 0xff0000ff );
+
+         if( lv )
+            vg_line( contact.pos, last, 0xffffffff );
+         v3_copy( contact.pos, last );
+         lv = 1;
       }
       else
       {
@@ -108,7 +188,9 @@ static void audio_sample_occlusion( v3f origin )
          vg_line( origin, p1, 0xffcccccc );
 
          d += sample_dist;
+         lv = 0;
       }
+
    }
 
    float occlusion = 1.0f - (d * (1.0f/(sample_dist*(float)sample_count))),
index c3ff3e97511e2c99386161c8c64fe7bf71f1a9a0..7f02ec0eee4e0f09e5b18bded7da3938bd266b61 100644 (file)
--- a/player.h
+++ b/player.h
@@ -719,6 +719,13 @@ static void player_physics(void)
          player.jump = 0.0f;
 
          player.jump_time = vg_time;
+
+         audio_lock();
+         audio_player_set_flags( &audio_player_extra, AUDIO_FLAG_SPACIAL_3D );
+         audio_player_set_position( &audio_player_extra, player.rb.co );
+         audio_player_set_vol( &audio_player_extra, 3.0f );
+         audio_player_playclip( &audio_player_extra, &audio_jumps[rand()%4] );
+         audio_unlock();
       }
    }
    else
@@ -802,6 +809,10 @@ static void player_do_motion(void)
 
          m3x3_copy( player.vr, player.gate_vr_frame );
          m3x3_copy( player.vr_pstep, player.gate_vr_pstep_frame );
+
+         audio_lock();
+         audio_play_oneshot( &audio_gate_lap, 1.0f );
+         audio_unlock();
          break;
       }
    }
@@ -1137,7 +1148,37 @@ static void player_animate_camera(void)
  */
 static void player_audio(void)
 {
+   static int _ding = 0;
+   
+   int last = _ding;
+   _ding = glfwGetKey(vg_window, GLFW_KEY_C);
+
+   int trigger_ding = 0;
+   if( _ding && !last )
+      trigger_ding = 1;
+
+   static int _air = 0;
+
+   int l2 = _air;
+   _air = player.in_air;
+
+   static double last_revert = -2000.0;
+
+
+
+
    audio_lock();
+   
+   double revert_delta = vg_time - last_revert;
+   if( (!_air && l2) && (fabsf(player.slip) > 0.5f) && (revert_delta > 0.7) )
+   {
+      audio_player_set_position( &audio_player_extra, player.rb.co );
+      audio_player_set_flags( &audio_player_extra, AUDIO_FLAG_SPACIAL_3D );
+      audio_player_set_vol( &audio_player_extra, 2.0f );
+      audio_player_playclip( &audio_player_extra, &audio_lands[rand()%5] );
+
+      last_revert = vg_time;
+   }
 
    static float air = 0.0f;
    air = vg_lerpf(air, player.in_air? 1.0f: 0.0f, 5.0f*ktimestep);
@@ -1148,10 +1189,14 @@ static void player_audio(void)
 
    float *cam = player.camera[3],
          *pos = player.rb.co;
+   
+   if( trigger_ding )
+      audio_player_playclip( &audio_player_extra, &audio_ding );
 
    audio_player_set_position( &audio_player0, player.rb.co );
    audio_player_set_position( &audio_player1, player.rb.co );
    audio_player_set_position( &audio_player2, player.rb.co );
+   audio_player_set_position( &audio_player_gate, world.render_gate_pos );
 
    v3_sub( player.rb.co, player.camera[3], delta );
    v3_normalize( delta );
@@ -1184,7 +1229,7 @@ static void player_audio(void)
       audio_player_set_vol( &audio_player1, vol1 );
       audio_player_set_vol( &audio_player2, vol2 );
 
-      float reverb_amt = vol0 * audio_occlusion_current * 1.0f;
+      float reverb_amt = vol0 * audio_occlusion_current * 0.5f;
       audio_player_set_pan( &audio_player3, 0.0f );
       audio_player_set_vol( &audio_player3, reverb_amt );
    }
diff --git a/sound_src/ding.ogg b/sound_src/ding.ogg
new file mode 100644 (file)
index 0000000..904467d
Binary files /dev/null and b/sound_src/ding.ogg differ
diff --git a/sound_src/gate_ambient.ogg b/sound_src/gate_ambient.ogg
new file mode 100644 (file)
index 0000000..3cf2dd7
Binary files /dev/null and b/sound_src/gate_ambient.ogg differ
diff --git a/sound_src/gate_lap.ogg b/sound_src/gate_lap.ogg
new file mode 100644 (file)
index 0000000..5bc5d73
Binary files /dev/null and b/sound_src/gate_lap.ogg differ
diff --git a/sound_src/gate_pass.ogg b/sound_src/gate_pass.ogg
new file mode 100644 (file)
index 0000000..9cbb487
Binary files /dev/null and b/sound_src/gate_pass.ogg differ
diff --git a/sound_src/revert0.ogg b/sound_src/revert0.ogg
new file mode 100644 (file)
index 0000000..632fcda
Binary files /dev/null and b/sound_src/revert0.ogg differ
diff --git a/sound_src/revert1.ogg b/sound_src/revert1.ogg
new file mode 100644 (file)
index 0000000..cd68628
Binary files /dev/null and b/sound_src/revert1.ogg differ
diff --git a/sound_src/revert2.ogg b/sound_src/revert2.ogg
new file mode 100644 (file)
index 0000000..e4b6296
Binary files /dev/null and b/sound_src/revert2.ogg differ
diff --git a/sound_src/revert3.ogg b/sound_src/revert3.ogg
new file mode 100644 (file)
index 0000000..920c9d7
Binary files /dev/null and b/sound_src/revert3.ogg differ
diff --git a/sound_src/revert4.ogg b/sound_src/revert4.ogg
new file mode 100644 (file)
index 0000000..a07274c
Binary files /dev/null and b/sound_src/revert4.ogg differ
diff --git a/sound_src/snap0.ogg b/sound_src/snap0.ogg
new file mode 100644 (file)
index 0000000..b9e5b1b
Binary files /dev/null and b/sound_src/snap0.ogg differ
diff --git a/sound_src/snap1.ogg b/sound_src/snap1.ogg
new file mode 100644 (file)
index 0000000..fb21ebc
Binary files /dev/null and b/sound_src/snap1.ogg differ
diff --git a/sound_src/snap2.ogg b/sound_src/snap2.ogg
new file mode 100644 (file)
index 0000000..8f266dd
Binary files /dev/null and b/sound_src/snap2.ogg differ
diff --git a/sound_src/snap3.ogg b/sound_src/snap3.ogg
new file mode 100644 (file)
index 0000000..4a5c3f5
Binary files /dev/null and b/sound_src/snap3.ogg differ
diff --git a/world.h b/world.h
index b76086f8c152a798bbcd65022028ba43ae918747..2fa7ce4f5ada984e5e4059d477e3e9eeb0823be7 100644 (file)
--- a/world.h
+++ b/world.h
@@ -86,6 +86,8 @@ static struct gworld
    * instance_cache;
    u32 instance_cache_count,
        instance_cache_cap;
+
+   v3f render_gate_pos;
 }
 world;
 
@@ -736,6 +738,10 @@ static void render_world_gates( m4x4f projection, m4x3f camera )
    }
 
    render_gate( &world.routes.gates[id].gate, camera );
+   v3_lerp( world.render_gate_pos, 
+            world.routes.gates[id].gate.co[0],
+            1.0f,
+            world.render_gate_pos );
 }
 
 static void render_world( m4x4f projection, m4x3f camera )