From: hgn Date: Wed, 28 Sep 2022 15:16:26 +0000 (+0100) Subject: latest X-Git-Url: https://harrygodden.com/git/?a=commitdiff_plain;ds=sidebyside;h=4625f91b85d2badbb719a7f5bcaa2426af25911b;p=carveJwlIkooP6JGAAIwe30JlM.git latest --- diff --git a/audio.h b/audio.h index 60ad27e..a981586 100644 --- 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 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 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 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 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 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 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 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 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 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 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 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 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 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 index 0000000..4a5c3f5 Binary files /dev/null and b/sound_src/snap3.ogg differ diff --git a/world.h b/world.h index b76086f..2fa7ce4 100644 --- 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 )