X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=world_render.c;h=8c346b677606b832313031a891f474bcfa2b20a8;hb=fbc68c65e01838feb77f47b30994b45fcc39ebaf;hp=4d5321bc2a2db50a019b8b141845b093a4603c56;hpb=23ba25574349652d86979fc787ec4b0214001333;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/world_render.c b/world_render.c index 4d5321b..8c346b6 100644 --- a/world_render.c +++ b/world_render.c @@ -95,7 +95,7 @@ static void world_render_init(void) mdl_context msky; mdl_open( &msky, "models/rs_skydome.mdl", vg_mem.scratch ); mdl_load_metadata_block( &msky, vg_mem.scratch ); - mdl_async_load_glmesh( &msky, &world_render.skydome ); + mdl_async_load_glmesh( &msky, &world_render.skydome, NULL ); mdl_close( &msky ); vg_info( "Loading default world textures\n" ); @@ -808,8 +808,10 @@ static void render_world_gates( world_instance *world, camera *cam ){ for( u32 i=0; ient_gate); i++ ){ ent_gate *gi = mdl_arritm( &world->ent_gate, i ); - if( !(gi->flags & k_ent_gate_linked) ) - continue; + + if( !(gi->flags & k_ent_gate_nonlocal) ) + if( !(gi->flags & k_ent_gate_linked) ) + continue; float dist = v3_dist2( gi->co[0], cam->transform[3] ); @@ -830,8 +832,10 @@ static void render_world_gates( world_instance *world, camera *cam ){ } if( gate->flags & k_ent_gate_nonlocal ){ - if( world_static.load_state != k_world_loader_none ){ + if( !(gate->flags & k_ent_gate_linked) || + (world_static.load_state != k_world_loader_none) ){ world->rendering_gate = NULL; + render_gate_unlinked( world, gate, cam ); return; } @@ -852,6 +856,10 @@ static void world_prerender( world_instance *world ){ world->time = 0.834; } + if( world->info.flags & 0x1 ){ + world->time = world->info.timezone; + } + struct ub_world_lighting *state = &world->ub_lighting; state->g_time = world->time;