X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;ds=inline;f=menu.h;h=3bbaf7c56ce1dcb859e20eab04a97b0a523c00cb;hb=330eda0436ed73d6c68214fef8922904abe19422;hp=fa2d5812dd5a31c4892b76a9015f7733105d1eff;hpb=53597f45307d8a2120e3a0bbe71797b216e8750b;p=carveJwlIkooP6JGAAIwe30JlM.git
diff --git a/menu.h b/menu.h
index fa2d581..3bbaf7c 100644
--- a/menu.h
+++ b/menu.h
@@ -11,6 +11,7 @@
#include "workshop.h"
#include "respawn.h"
#include "gui.h"
+#include "ent_miniworld.h"
#define MENU_STACK_SIZE 8
@@ -129,7 +130,7 @@ static void menu_close(void){
skaterift.activity = k_skaterift_default;
menu.page_depth = 0;
menu.page = 0xffffffff;
- srinput.enabled = 0;
+ srinput.state = k_input_state_resume;
}
static void menu_init(void){
@@ -245,22 +246,10 @@ static void menu_trigger_item( ent_menuitem *item ){
vg.window_should_close = 1;
}
- /* DEPRECATED? */
- else if( MDL_CONST_PSTREQ( &menu.model, q, "reset_nearest" ) ){
- localplayer_cmd_respawn( 0, NULL );
- menu_close();
- }
- /* DEPRECATED? */
- else if( MDL_CONST_PSTREQ( &menu.model, q, "reset_home" ) ){
- world_set_active_instance( 0 );
- localplayer.viewable_world = world_current_instance();
- localplayer_cmd_respawn( 1, (const char *[]){"start"} );
- menu_close();
- }
-
else if( MDL_CONST_PSTREQ( &menu.model, q, "reset" ) ){
+ srinput.state = k_input_state_resume;
menu_close();
- respawn_begin_chooser();
+ ent_miniworld_goback();
}
else if( MDL_CONST_PSTREQ( &menu.model, q, "credits" ) ){
@@ -430,7 +419,8 @@ static void menu_update(void){
ent_menuitem *item = mdl_arritm( &menu.items, i );
if( item->type == k_ent_menuitem_type_page ) continue;
- if( item->type == k_ent_menuitem_type_visual ) continue;
+ if( (item->type == k_ent_menuitem_type_visual) ||
+ (item->type == k_ent_menuitem_type_visual_nocol) ) continue;
if( item->type == k_ent_menuitem_type_binding ) continue;
if( !(item->groups & (0x1<
type != k_ent_menuitem_type_page) &&
(item->type != k_ent_menuitem_type_visual) &&
+ (item->type != k_ent_menuitem_type_visual_nocol) &&
(item->groups & (0x1<transform, (v3f){0.0f,-1.0f,0.0f}, v0 );
- player_vector_angles( target.angles, v0, 1.0f, 0.0f );
+ v3_angles( v0, target.angles );
camera_lerp( &menu.view, &target, rate, &menu.view );
@@ -707,7 +698,7 @@ VG_STATIC void menu_render(void){
}
}
- if( item->type == k_ent_menuitem_type_visual ){
+ if( item->type == k_ent_menuitem_type_visual_nocol ){
shader_model_menu_uColour( (v4f){1.0f,1.0f,1.0f,1.0f} );
}
else{
@@ -761,7 +752,7 @@ VG_STATIC void menu_render(void){
m4x3f local;
m4x3_identity( local );
- font3d_bind( &gui.font, &menu.view );
+ font3d_bind( &gui.font, k_font_shader_default, 0, NULL, &menu.view );
for( u32 i=0; ibinding.font_variant;
menu_binding_string( buf, item->binding.pstr_bind );
- f32 offset = font3d_string_width( &gui.font, variant, buf );
+ f32 offset = font3d_string_width( variant, buf );
local[3][0] = -0.5f * offset;
m4x3_mul( transform, local, transform );
- font3d_simple_draw( &gui.font, variant, k_font_shader_default, buf,
- &menu.view, transform );
+ font3d_simple_draw( variant, buf, &menu.view, transform );
}
}
-VG_STATIC void menu_binding_string( char buf[128], u32 pstr ){
- vg_strncpy( "error", buf, 128, k_strncpy_allow_cutoff );
+static void menu_binding_string( char buf[128], u32 pstr ){
+ vg_str str;
+ vg_strnull( &str, buf, 128 );
if( MDL_CONST_PSTREQ( &menu.model, pstr, "bind_jump" ) ){
- vg_strncpy( button_display_string(k_srbind_jump), buf, 128,
- k_strncpy_allow_cutoff );
+ vg_input_string( &str, input_button_list[k_srbind_jump], 1 );
}
else if( MDL_CONST_PSTREQ( &menu.model, pstr, "bind_trick0" ) ){
- vg_str str;
- vg_strnull( &str, buf, 128 );
vg_strcat( &str, "SHUVIT " );
- vg_strcat( &str, button_display_string(k_srbind_trick0) );
+ vg_input_string( &str, input_button_list[k_srbind_trick0], 1 );
}
else if( MDL_CONST_PSTREQ( &menu.model, pstr, "bind_trick1" ) ){
- vg_str str;
- vg_strnull( &str, buf, 128 );
vg_strcat( &str, "KICKFLIP " );
- vg_strcat( &str, button_display_string(k_srbind_trick1) );
+ vg_input_string( &str, input_button_list[k_srbind_trick1], 1 );
}
else if( MDL_CONST_PSTREQ( &menu.model, pstr, "bind_trick2" ) ){
- vg_str str;
- vg_strnull( &str, buf, 128 );
vg_strcat( &str, "TREFLIP " );
- vg_strcat( &str, button_display_string(k_srbind_trick2) );
+ vg_input_string( &str, input_button_list[k_srbind_trick2], 1 );
}
else if( MDL_CONST_PSTREQ( &menu.model, pstr, "bind_grab" ) ){
- vg_strncpy( axis_display_string(k_sraxis_grab), buf, 128,
- k_strncpy_allow_cutoff );
+ vg_input_string( &str, input_axis_list[k_sraxis_grab], 1 );
}
else if( MDL_CONST_PSTREQ( &menu.model, pstr, "bind_grab_mod" ) ){
- vg_strncpy( joystick_display_string(k_srjoystick_grab, 2), buf, 128,
- k_strncpy_allow_cutoff );
+ vg_input_string( &str, input_joy_list[k_srjoystick_grab], 1 );
}
+ else
+ vg_strcat( &str, "error" );
}
#endif /* MENU_H */