X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=world.h;h=e23ae219e3abca7e8d610fbf53b0db6f3deb57ef;hb=eb203257efcfe324217de9e733cc6c1371b99de6;hp=08d3ca09123d253651cc89fecc653e36f1468718;hpb=4b8aac300ee193cfa12011dfe0238cfe7d7ffce7;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/world.h b/world.h index 08d3ca0..e23ae21 100644 --- a/world.h +++ b/world.h @@ -118,6 +118,8 @@ struct world_instance tex_light_entities, tex_light_cubes; + float probabilities[3]; + v3i light_cubes; struct framebuffer heightmap; @@ -496,12 +498,10 @@ VG_STATIC void ent_volume_call( world_instance *world, ent_call *call ) call->function = k_ent_function_particle_spawn; call->data = co; - entity_call( world, call ); } - else if( volume->type == k_volume_subtype_trigger ){ - /* TODO */ - } + else + entity_call( world, call ); } } @@ -509,26 +509,83 @@ VG_STATIC void ent_audio_call( world_instance *world, ent_call *call ) { ent_audio *audio = mdl_arritm( &world->ent_audio, call->ent.index ); + v3f sound_co; + if( call->function == k_ent_function_particle_spawn ){ - float chance = vg_randf()*100.0f, - bar = 0.0f; + v3_copy( call->data, sound_co ); + } + else if( call->function == k_ent_function_trigger ){ + v3_copy( audio->transform.co, sound_co ); + } + else + vg_fatal_exit_loop( "ent_audio_call (invalid function id)" ); + + float chance = vg_randf()*100.0f, + bar = 0.0f; + + for( u32 i=0; iclip_count; i++ ){ + ent_audio_clip *clip = mdl_arritm( &world->ent_audio_clip, + audio->clip_start+i ); - for( u32 i=0; iclip_count; i++ ){ - ent_audio_clip *clip = mdl_arritm( &world->ent_audio_clip, - audio->clip_start+i ); + float mod = world->probabilities[ audio->probability_curve ], + p = clip->probability * mod; - bar += clip->probability; + bar += p; - if( chance < bar ){ - float *pos = call->data; + if( chance < bar ){ - audio_lock(); - audio_oneshot_3d( &clip->clip, pos, + audio_lock(); + + if( audio->behaviour == k_channel_behaviour_unlimited ){ + audio_oneshot_3d( &clip->clip, sound_co, audio->transform.s[0], audio->volume ); - audio_unlock(); - break; } + else if( audio->behaviour == k_channel_behaviour_discard_if_full ){ + audio_channel *ch = + audio_get_group_idle_channel( audio->group, + audio->max_channels ); + + if( ch ){ + audio_channel_init( ch, &clip->clip, audio->flags ); + audio_channel_group( ch, audio->group ); + audio_channel_set_spacial( ch, sound_co, audio->transform.s[0] ); + audio_channel_edit_volume( ch, audio->volume, 1 ); + ch = audio_relinquish_channel( ch ); + } + } + else if( audio->behaviour == k_channel_behaviour_crossfade_if_full){ + audio_channel *ch = + audio_get_group_idle_channel( audio->group, + audio->max_channels ); + + /* group is full */ + if( !ch ){ + audio_channel *existing = + audio_get_group_first_active_channel( audio->group ); + + if( existing ){ + if( existing->source == &clip->clip ){ + audio_unlock(); + return; + } + + existing = audio_channel_fadeout( existing, audio->crossfade); + } + + ch = audio_get_first_idle_channel(); + } + + if( ch ){ + audio_channel_init( ch, &clip->clip, audio->flags ); + audio_channel_group( ch, audio->group ); + audio_channel_fadein( ch, audio->crossfade ); + ch = audio_relinquish_channel( ch ); + } + } + + audio_unlock(); + return; } } } @@ -571,6 +628,15 @@ VG_STATIC void world_update( world_instance *world, v3f pos ) v3_normalize( state->g_sun_dir ); + world->probabilities[ k_probability_curve_constant ] = 1.0f; + + float dp = state->g_day_phase; + + world->probabilities[ k_probability_curve_wildlife_day ] = + (dp*dp*0.8f+state->g_sunset_phase)*0.8f; + world->probabilities[ k_probability_curve_wildlife_night ] = + 1.0f-powf(fabsf((state->g_time_of_day-0.5f)*5.0f),5.0f); + glBindBuffer( GL_UNIFORM_BUFFER, world->ubo_lighting ); glBufferSubData( GL_UNIFORM_BUFFER, 0, @@ -656,13 +722,13 @@ VG_STATIC void world_update( world_instance *world, v3f pos ) if( volume->type == k_volume_subtype_trigger ){ v3f local; m4x3_mulv( volume->to_local, pos, local ); - vg_line_boxf_transformed( volume->to_world, cube, 0xff00ff00 ); if( (fabsf(local[0]) <= 1.0f) && (fabsf(local[1]) <= 1.0f) && (fabsf(local[2]) <= 1.0f) ) { in_volume = 1; + vg_line_boxf_transformed( volume->to_world, cube, 0xff00ff00 ); if( !world_global.in_volume ){ ent_call basecall; @@ -674,6 +740,8 @@ VG_STATIC void world_update( world_instance *world, v3f pos ) entity_call( world, &basecall ); } } + else + vg_line_boxf_transformed( volume->to_world, cube, 0xff0000ff ); } else if( volume->type == k_volume_subtype_particle ){ vg_line_boxf_transformed( volume->to_world, cube, 0xff00c0ff );