- glBindFramebuffer( GL_FRAMEBUFFER, 0 );
- glViewport( 0,0, vg_window_x, vg_window_y );
-
- glDisable( GL_DEPTH_TEST );
- glClearColor( 0.1f, 0.0f, 0.2f, 1.0f );
- glClearColor(111.0f/255.0f, 46.0f/255.0f, 45.0f/255.0f,1.0f);
-
- glClearColor( powf(0.066f,1.0f/2.2f),
- powf(0.050f,1.0f/2.2f),
- powf(0.046f,1.0f/2.2f), 1.0f );
- glClear( GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT );
-
- v3f pos_inv;
- static v3f cam_lerped = {0.0f,0.0f,0.0f};
- v3_lerp( cam_lerped, player.view, 0.08f, cam_lerped );
-
- if( !freecam )
- {
- m4x3_mulv( player.to_world, cam_lerped, pos_inv );
-
- static float air_blend = 0.0f;
-
- air_blend = vg_lerpf( air_blend, player.in_air, 0.04f );
- v3_muladds( pos_inv, player.v, -0.05f*air_blend, pos_inv );
- }
- else
- v3_add( player.co, player.view, pos_inv );
- v3_negate( pos_inv, pos_inv );
-
- static float vertical_lerp = 0.0f;
- vertical_lerp = vg_lerpf( vertical_lerp, pos_inv[1], 1.0f );
- v3f final = { pos_inv[0], vertical_lerp, pos_inv[2] };
-
- float speed = freecam? 0.0f: v3_length( player.v );
- v3f shake = { vg_randf()-0.5f, vg_randf()-0.5f, vg_randf()-0.5f };
- v3_muls( shake, speed*0.01f, shake );
-
- static v2f cam_lerped_dir;
-
- m4x3_identity( world_matrix );
- if( player.is_dead )
- {
- v3f delta;
- v3_sub( player.mdl.ragdoll[k_chpart_head].co, player.follow, delta );
- v3_normalize(delta);
-
- v3f follow_pos;
- v3_muladds( player.mdl.ragdoll[k_chpart_head].co, delta,
- -1.5f, follow_pos );
- v3_lerp( player.follow, follow_pos, 0.1f, player.follow );
- v3_negate( player.follow, final );
-
-
- float yaw = atan2f( delta[0], -delta[2] );
- float pitch = asinf( delta[1] );
- m4x3_rotate_x( world_matrix, -pitch );
- m4x3_rotate_y( world_matrix, yaw );
- }
- else
- {
- v2_lerp( cam_lerped_dir, player.look_dir, 0.04f, cam_lerped_dir );
-
- m4x3_rotate_x( world_matrix,
- freecam?
- cam_lerped_dir[1]:
- 0.6f+shake[1]*0.04f+player.look_dir[1] );
-
- m4x3_rotate_y( world_matrix,
- freecam?
- cam_lerped_dir[0]:
- player.look_dir[0]+shake[0]*0.02f );
- }
-
-
- m4x3_translate( world_matrix, final );
-
- m4x4f world_4x4;
- m4x3_expand( world_matrix, world_4x4 );
- m4x4_projection( vg_pv,
- freecam? 60.0f: 120.0f,
- (float)vg_window_x / (float)vg_window_y,
- 0.01f, 1000.0f );
- m4x4_mul( vg_pv, world_4x4, vg_pv );
-
- vg_line( (v3f){ 0.0f, 0.0f, 0.0f }, (v3f){ 1.0f, 0.0f, 0.0f }, 0xffff0000 );
- vg_line( (v3f){ 0.0f, 0.0f, 0.0f }, (v3f){ 0.0f, 1.0f, 0.0f }, 0xff00ff00 );
- vg_line( (v3f){ 0.0f, 0.0f, 0.0f }, (v3f){ 0.0f, 0.0f, 1.0f }, 0xff0000ff );
-
- glEnable( GL_DEPTH_TEST );
-
- /*
- * Draw world
- */
- SHADER_USE(shader_standard_lit);
-
- m4x3f identity_matrix;
- m4x3_identity( identity_matrix );
-
- glUniformMatrix4fv( SHADER_UNIFORM( shader_standard_lit, "uPv" ),
- 1, GL_FALSE, (float *)vg_pv );
- glUniformMatrix4x3fv( SHADER_UNIFORM( shader_standard_lit, "uMdl" ),
- 1, GL_FALSE, (float *)identity_matrix );
-
- vg_tex2d_bind( &tex_grid, 0 );
- glUniform1i( SHADER_UNIFORM( shader_standard_lit, "uTexMain" ), 0 );
-
- glUniform4f( SHADER_UNIFORM(shader_standard_lit,"uColour"),
- 0.4f,0.4f,0.4f,1.0f );
-
- scene_bind( &world.geo );
- scene_draw( &world.geo );
-
-#if 0
- if( !replay_record )
- {
- m4x3f *base = &replay_buffer[(PART_COUNT)*replay_buffer_frame];
-
- for( int i=0; i<PART_COUNT; i++ )
- m4x3_copy( base[i], player.mdl.matrices[i] );