X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=player.h;h=57a862817038bb5bf798118617d42a3ed45d2589;hb=da929c58442de91be106438ebf2f2daabf7f2430;hp=0a226afaffe04541c3315dfc602dd81f859c88f0;hpb=c2d67378dd5c82de50b8fbbbe222ec6be2da4eee;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/player.h b/player.h index 0a226af..57a8628 100644 --- a/player.h +++ b/player.h @@ -1,10 +1,5 @@ /* - * Copyright 2021-2022 (C) Mount0 Software, Harry Godden - All Rights Reserved - * ----------------------------------------------------------------------------- - * - * Player head module - * - * ----------------------------------------------------------------------------- + * Copyright (C) 2021-2022 Mt.ZERO Software, Harry Godden - All Rights Reserved */ #ifndef PLAYER_H @@ -17,8 +12,8 @@ #include "bvh.h" static float - k_walkspeed = 7.0f, /* no longer used */ - k_runspeed = 14.0f, + k_walkspeed = 20.0f, /* no longer used */ + k_runspeed = 20.0f, k_board_radius = 0.3f, k_board_length = 0.45f, k_board_allowance = 0.04f, @@ -32,11 +27,12 @@ static float k_steer_air_lerp = 0.3f, k_pump_force = 0.0f, k_downforce = 5.0f, + k_walk_downforce = 8.0f, k_jump_charge_speed = (1.0f/1.0f), k_jump_force = 5.0f, k_pitch_limit = 1.5f, k_look_speed = 2.0f, - k_walk_accel = 5.0f, + k_walk_accel = 150.0f, k_walk_friction = 8.0f; static int freecam = 0; @@ -65,7 +61,8 @@ static struct gplayer float vswitch, slip, slip_last, reverse; - float grab, jump; + float grab, jump, pushing, push_time; + double start_push; int in_air, on_board, jump_charge, jump_dir; m3x3f vr,vr_pstep; @@ -73,7 +70,6 @@ static struct gplayer phys, phys_gate_frame; - float pushing, push_time; int is_dead; v3f land_target; @@ -118,7 +114,8 @@ static struct gplayer *anim_push, *anim_push_reverse, *anim_ollie, *anim_ollie_reverse, *anim_grabs, *anim_stop, - *anim_walk, *anim_run, *anim_idle; + *anim_walk, *anim_run, *anim_idle, + *anim_jump; u32 id_hip, id_ik_hand_l, @@ -177,7 +174,7 @@ static void player_restore_frame(void); * ----------------------------------------------------------------------------- */ -static int player_init(void) /* 1 */ +static void player_init(void) /* 1 */ { rb_init( &player.phys.rb ); rb_init( &player.collide_front ); @@ -228,18 +225,16 @@ static int player_init(void) /* 1 */ .function = reset_player }); - return player_model_init(); + /* other systems */ + vg_loader_highwater( player_model_init, player_model_free, NULL ); } -static void player_update(void) /* 2 */ +/* Deal with input etc */ +static void player_update_pre(void) { struct player_phys *phys = &player.phys; - for( int i=0; i0.0f) + if( vg_get_button_down( "reset" ) ) { player.is_dead = 0; player_restore_frame(); @@ -259,19 +254,41 @@ static void player_update(void) /* 2 */ if( vg_get_button_down( "switchmode" ) ) { phys->on_board ^= 0x1; + + if( phys->on_board ) + { + v3_muladds( phys->rb.v, phys->rb.forward, 0.2f, phys->rb.v ); + } } +} -#if 0 - if( (glfwGetKey( vg_window, GLFW_KEY_O ) )) +static void player_update_fixed(void) /* 2 */ +{ + struct player_phys *phys = &player.phys; + + if( player.is_dead ) { - player_ragdoll_copy_model( phys->rb.v ); - player.is_dead = 1; + player_ragdoll_iter(); } -#endif + else + { + player_do_motion(); + } + + player_audio(); /* FUTURE: can probably move this to post() + BUT, it uses deltas from fixed step physics, + AND this *might* be what we want for realtime + audio, anyway. */ +} + +static void player_update_post(void) +{ + for( int i=0; i