#}
class ent_menuitem_button(Structure):
#{
- _fields_ = [("pstr",c_uint32)]
+ _fields_ = [("pstr",c_uint32),
+ ("stack_behaviour",c_uint32)]
#}
class ent_menuitem_checkmark(Structure):
#{
("id_entrypoint",c_uint32),
("id_viewpoint",c_uint32)]
#}
+class ent_menuitem_binding(Structure):
+#{
+ _fields_ = [("pstr_bind",c_uint32),
+ ("font_variant",c_uint32)]
+#}
class ent_menuitem_anon_union(Union):
#{
_fields_ = [("slider",ent_menuitem_slider),
("button",ent_menuitem_button),
("checkmark",ent_menuitem_checkmark),
("page",ent_menuitem_page),
- ("visual",ent_menuitem_visual)]
+ ("visual",ent_menuitem_visual),
+ ("binding",ent_menuitem_binding)]
#}
class ent_menuitem(Structure):
#{
if item.type == 1 or item.type == 2:#{
item_button = item._anonymous_union.button
item_button.pstr = sr_compile_string( obj_data.string )
+ item_button.stack_behaviour = int( obj_data.stack_behaviour )
#}
elif item.type == 0:#{
item_visual = item._anonymous_union.visual
item_page.id_entrypoint = sr_entity_id( obj_data.newloc )
item_page.id_viewpoint = sr_entity_id( obj_data.camera )
#}
+ elif item.type == 6:#{
+ item_binding = item._anonymous_union.binding
+ item_binding.pstr_bind = sr_compile_string( obj_data.string )
+ item_binding.font_variant = obj_data.font_variant
+ #}
if obj_data.link0:
item.id_links[0] = sr_entity_id( obj_data.link0 )
newloc: bpy.props.PointerProperty( \
type=bpy.types.Object, name="New location", \
poll=lambda self,obj: sr_filter_ent_type(obj,['ent_menuitem']))
+ stack_behaviour: bpy.props.EnumProperty( name='Stack Behaviour',
+ items=[('0','append',''),
+ ('1','replace','')])
+
camera: bpy.props.PointerProperty( \
type=bpy.types.Object, name="Camera", \
poll=lambda self,obj: sr_filter_ent_type(obj,['ent_camera']))
type=bpy.types.Object, name="Checked", \
poll=lambda self,obj: sr_filter_ent_type(obj,['ent_menuitem']))
+ font_variant: bpy.props.IntProperty( name="Font Variant" )
+
string: bpy.props.StringProperty( name="String" )
tipo: bpy.props.EnumProperty( name='Type',
items=[('0','visual',''),
('2','page button',''),
('3','toggle', ''),
('4','slider',''),
- ('5','page','')])
+ ('5','page',''),
+ ('6','binding','')])
@staticmethod
def sr_inspector( layout, data ):
#}
elif data.tipo == '2':#{
box.prop( data, 'string', text='Page' )
- box.prop( data, 'newloc' )
+ box.prop( data, 'stack_behaviour' )
#}
elif data.tipo == '3':#{
box.prop( data, 'string', text='Data (i32)' )
box.prop( data, 'camera', text='Viewpoint' )
return
#}
+ elif data.tipo == '6':#{
+ box.prop( data, 'string', text='ID' )
+ box.prop( data, 'font_variant' )
+ return
+ #}
box = box.box()
box.label( text="Links" )
#include "input.h"
#include "workshop.h"
#include "respawn.h"
+#include "gui.h"
#define MENU_STACK_SIZE 8
* Drop back a page until we're at the bottom which then we jus quit
*/
static void menu_back_page(void){
- vg_info( "menu_back_page()\n" );
menu.page_depth --;
if( menu.page_depth == 0 ){
menu_close();
/*
* Open page to the string identifier
*/
-static void menu_open_page( const char *name ){
- if( menu.page_depth >= MENU_STACK_SIZE )
- vg_fatal_error( "Stack overflow\n" );
-
- vg_info( "Try to open %s\n", name );
+static void menu_open_page( const char *name,
+ enum ent_menuitem_stack_behaviour stackmode ){
+ if( stackmode == k_ent_menuitem_stack_append ){
+ if( menu.page_depth >= MENU_STACK_SIZE )
+ vg_fatal_error( "Stack overflow\n" );
+ }
+ else{
+ if( menu.page_depth == 0 )
+ vg_fatal_error( "Stack underflow\n" );
+ }
u32 hash = vg_strdjb2( name );
for( u32 i=0; i<mdl_arrcount(&menu.items); i++ ){
u32 new_page = __builtin_ctz( item->groups );
if( new_page == menu.page ){
- menu_back_page();
+ if( stackmode != k_ent_menuitem_stack_replace )
+ menu_back_page();
}
else{
- menu.page_stack[ menu.page_depth ].page = menu.page;
- menu.page_stack[ menu.page_depth ].cam = menu.cam;
- menu.page_stack[ menu.page_depth ++ ].loc = menu.loc;
+ menu.page_stack[ menu.page_depth ].page = menu.page;
+ menu.page_stack[ menu.page_depth ].cam = menu.cam;
+ menu.page_stack[ menu.page_depth ].loc = menu.loc;
+
+ if( stackmode == k_ent_menuitem_stack_append )
+ menu.page_depth ++;
+
menu.page = __builtin_ctz( item->groups );
if( menu.input_mode == k_menu_input_mode_keys ){
u32 id = mdl_entity_id_id( item->page.id_viewpoint );
menu.cam = mdl_arritm( &menu.cameras, id );
}
- vg_info( "menu page: %u (%p,%p)\n",
- menu.page, menu.loc, menu.cam );
}
return;
}
}
}
else if( item->type == k_ent_menuitem_type_page_button ){
- menu_open_page( mdl_pstr( &menu.model, item->button.pstr ) );
+ menu_open_page( mdl_pstr( &menu.model, item->button.pstr ),
+ item->button.stack_behaviour );
}
else if( item->type == k_ent_menuitem_type_toggle ){
if( item->pi32 ){
if( skaterift.activity == k_skaterift_default ){
skaterift.activity = k_skaterift_menu;
menu.page = 0xffffffff;
- menu_open_page( "Main Menu" );
+ menu_open_page( "Main Menu", k_ent_menuitem_stack_append );
return;
}
}
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_binding ) continue;
if( !(item->groups & (0x1<<menu.page)) ) continue;
ent_menuitem *ray_item = item;
}
}
+VG_STATIC void menu_binding_string( char buf[128], u32 pstr );
+
/*
* Run from vg_gui when active
*/
ui_hex_to_norm( ui_colour( k_ui_fg ), white );
ui_hex_to_norm( ui_colour( k_ui_orange+k_ui_brighter ), blue );
+ ent_menuitem *text_list[ 8 ];
+ u32 text_count = 0;
+
for( u32 i=0; i<mdl_arrcount(&menu.items); i++ ){
ent_menuitem *item = mdl_arritm( &menu.items, i );
if( item->type == k_ent_menuitem_type_page ) continue;
if( !(item->groups & (0x1 << menu.page)) ) continue;
+ if( item->type == k_ent_menuitem_type_binding ){
+ if( text_count < vg_list_size(text_list) )
+ text_list[ text_count ++ ] = item;
+ else
+ vg_fatal_error( "Text list overflow" );
+
+ continue;
+ }
+
int selected = 0;
if( menu.loc ){
}
}
- item->factive = vg_lerpf( item->factive, selected, rate );
- v4f colour;
- v4_lerp( white, blue, item->factive, colour );
- shader_model_menu_uColour( colour );
+ if( item->type == k_ent_menuitem_type_visual ){
+ shader_model_menu_uColour( (v4f){1.0f,1.0f,1.0f,1.0f} );
+ }
+ else{
+ v4f colour;
+ item->factive = vg_lerpf( item->factive, selected, rate );
+ v4_lerp( white, blue, item->factive, colour );
+ shader_model_menu_uColour( colour );
+ }
f32 scale = 1.0f+item->factive*0.1f;
mdl_draw_submesh( mdl_arritm( &menu.model.submeshs, index ));
}
}
+
+ if( !text_count ) return;
+
+ char buf[ 128 ];
+
+ m4x3f local;
+ m4x3_identity( local );
+
+ font3d_bind( &gui.font, &menu.view );
+ for( u32 i=0; i<text_count; i++ ){
+ ent_menuitem *item = text_list[ i ];
+ m4x3f transform;
+ mdl_transform_m4x3( &item->transform, transform );
+
+ u32 variant = item->binding.font_variant;
+ menu_binding_string( buf, item->binding.pstr_bind );
+ f32 offset = font3d_string_width( &gui.font, 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 );
+ }
+}
+
+VG_STATIC void menu_binding_string( char buf[128], u32 pstr ){
+ vg_strncpy( "error", buf, 128, k_strncpy_allow_cutoff );
+
+ if( MDL_CONST_PSTREQ( &menu.model, pstr, "bind_jump" ) ){
+ vg_strncpy( button_display_string(k_srbind_jump), buf, 128,
+ k_strncpy_allow_cutoff );
+ }
+ 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) );
+ }
+ 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) );
+ }
+ 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) );
+ }
+ else if( MDL_CONST_PSTREQ( &menu.model, pstr, "bind_grab" ) ){
+ vg_strncpy( axis_display_string(k_sraxis_grab), buf, 128,
+ k_strncpy_allow_cutoff );
+ }
+ 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 );
+ }
}
#endif /* MENU_H */