X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=menu.c;h=eaec9073b699137a47942f143c3301bb4dbe92ee;hb=5bb71fef0e63780f95f403fb14b824778cecbe9b;hp=daeb61a2b6057ce7c3d7422c1f03edd9c236d3f6;hpb=95f6ef1a859423a0d9554ac6a9f4c6cbd8bb540c;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/menu.c b/menu.c index daeb61a..eaec907 100644 --- a/menu.c +++ b/menu.c @@ -219,7 +219,7 @@ static bool menu_checkbox( ui_rect inout_panel, bool select, return changed; } -static void menu_heading( ui_rect inout_panel, const char *label ) +static void menu_heading( ui_rect inout_panel, const char *label, u32 colour ) { ui_rect rect; menu_standard_widget( inout_panel, rect, 1 ); @@ -239,10 +239,19 @@ static void menu_heading( ui_rect inout_panel, const char *label ) ui_text( rect, label, 1, k_ui_align_middle_center, 1 ); rect[0] += 1; rect[1] -= 1; - ui_text( rect, label, 1, k_ui_align_middle_center, + ui_text( rect, label, 1, k_ui_align_middle_center, colour? colour: ui_colour(k_ui_blue+k_ui_brighter) ); } +static u32 medal_colour( u32 flags ) +{ + if( flags & k_ent_route_flag_achieve_gold ) + return ui_colour( k_ui_yellow ); + else if( flags & k_ent_route_flag_achieve_silver ) + return ui_colour( k_ui_fg ); + else return 0; +} + void menu_gui(void) { if( button_down( k_srbind_mopen ) ) @@ -461,12 +470,13 @@ void menu_gui(void) vg_strnull( &str, buf, sizeof(buf) ); vg_strcat( &str, "Hub World" ); - if( world_static.active_instance && - (vg_input.display_input_method == k_input_method_controller) ) + if( world_static.active_instance ) { vg_strcat( &str, " (" ); vg_input_string( &str, input_button_list[k_srbind_mhub], 1 ); - vg_strcat( &str, ")" ); + vg_strcatch( &str, '\x06' ); + vg_strcatch( &str, '\x00' ); + vg_strcat( &str, "\x1B[0m)" ); } ui_px w = ui_text( (ui_rect){ x+8, y, 1000, height }, buf, 1, @@ -493,7 +503,9 @@ void menu_gui(void) { vg_strcat( &str, " (" ); vg_input_string( &str, input_button_list[k_srbind_mhub], 1 ); - vg_strcat( &str, ")" ); + vg_strcatch( &str, '\x06' ); + vg_strcatch( &str, '\x00' ); + vg_strcat( &str, "\x1B[0m)" ); } vs = ui_fill( (ui_rect){ x,y, 1000,height }, @@ -516,6 +528,119 @@ void menu_gui(void) vs[1].co[0] = x + 8; vs[2].co[0] = x; } + + x = 8; + y += 8 + height; + + if( world_static.active_instance ) + { + ui_rect stat_panel = { x,y, 256,vg.window_y-y }; + u32 c0 = ui_opacity( GUI_COL_DARK, 0.36f ); + struct ui_vert *vs = ui_fill( stat_panel, c0 ); + + ui_rect_pad( stat_panel, (ui_px[2]){8,0} ); + + for( u32 i=0; ient_region ); i ++ ) + { + ent_region *region = mdl_arritm( &world->ent_region, i ); + + if( !region->zone_volume ) + continue; + + const char *title = mdl_pstr( &world->meta, region->pstr_title ); + ui_font_face( &vgf_default_large ); + + ui_rect title_box; + menu_standard_widget( stat_panel, title_box, 1 ); + + stat_panel[0] += 16; + stat_panel[2] -= 16; + ui_font_face( &vgf_default_small ); + + ent_volume *volume = mdl_arritm(&world->ent_volume, + mdl_entity_id_id(region->zone_volume)); + + u32 combined = k_ent_route_flag_achieve_gold | + k_ent_route_flag_achieve_silver; + + char buf[128]; + vg_str str; + + for( u32 j=0; jent_route); j ++ ) + { + ent_route *route = mdl_arritm(&world->ent_route, j ); + + v3f local; + m4x3_mulv( volume->to_local, route->board_transform[3], local ); + if( !((fabsf(local[0]) <= 1.0f) && + (fabsf(local[1]) <= 1.0f) && + (fabsf(local[2]) <= 1.0f)) ) + { + continue; + } + + combined &= route->flags; + + vg_strnull( &str, buf, sizeof(buf) ); + vg_strcat( &str, mdl_pstr(&world->meta, route->pstr_name)); + + if( route->flags & k_ent_route_flag_achieve_silver ) + vg_strcat( &str, " \xb3"); + if( route->flags & k_ent_route_flag_achieve_gold ) + vg_strcat( &str, "\xb3"); + + ui_rect r; + ui_standard_widget( stat_panel, r, 1 ); + ui_text( r, buf, 1, k_ui_align_middle_left, + medal_colour(route->flags) ); + } + + for( u32 j=0; jent_challenge); j ++ ) + { + ent_challenge *challenge = mdl_arritm( &world->ent_challenge, j ); + + v3f local; + m4x3_mulv( volume->to_local, challenge->transform.co, local ); + if( !((fabsf(local[0]) <= 1.0f) && + (fabsf(local[1]) <= 1.0f) && + (fabsf(local[2]) <= 1.0f)) ) + { + continue; + } + + vg_strnull( &str, buf, sizeof(buf) ); + vg_strcat( &str, mdl_pstr(&world->meta, challenge->pstr_alias)); + + u32 flags = 0x00; + if( challenge->status ) + { + flags |= k_ent_route_flag_achieve_gold; + flags |= k_ent_route_flag_achieve_silver; + vg_strcat( &str, " \xb3\xb3" ); + } + + combined &= flags; + + ui_rect r; + ui_standard_widget( stat_panel, r, 1 ); + ui_text( r, buf, 1, k_ui_align_middle_left, medal_colour(flags) ); + } + + stat_panel[0] -= 16; + stat_panel[2] += 16; + + u32 title_col = 0; + if( combined & k_ent_route_flag_achieve_gold ) + title_col = ui_colour( k_ui_yellow ); + else if( combined & k_ent_route_flag_achieve_silver ) + title_col = ui_colour( k_ui_fg ); + + menu_heading( title_box, title, title_col ); + } + + vs[2].co[1] = stat_panel[1]; + vs[3].co[1] = stat_panel[1]; + } } else { @@ -573,20 +698,20 @@ void menu_gui(void) ui_font_face( &vgf_default_large ); list[1] -= 8; - menu_heading( list, "Game" ); + menu_heading( list, "Game", 0 ); menu_checkbox( list, *row == 0, "Show controls overlay", &control_overlay.enabled ); menu_checkbox( list, *row == 1, "Auto connect to global server", &network_client.auto_connect ); - menu_heading( list, "Audio/Video" ); + menu_heading( list, "Audio/Video", 0 ); menu_slider( list, *row == 2, "Volume", 0, 100, &vg_audio.external_global_volume, "%.f%%" ); menu_slider( list, *row == 3, "Resolution", 0, 100, &k_render_scale, "%.f%%" ); menu_checkbox( list, *row == 4, "Motion Blur", &k_blur_effect ); - menu_heading( list, "Camera" ); + menu_heading( list, "Camera", 0 ); menu_slider( list, *row == 5, "Fov", 97, 135, &k_fov, "%.1f\xb0" ); menu_slider( list, *row == 6, "Cam Height", -0.4f, +1.4f, @@ -597,7 +722,7 @@ void menu_gui(void) ui_rect end = { list[0], list[1]+list[3]-64, list[2], 72 }; ui_font_face( &vgf_default_small ); - menu_heading( end, "Advanced" ); + menu_heading( end, "Advanced", 0 ); if( menu_button( end, *row == 8, "Open Engine Settings" ) ) { vg_settings_open(); @@ -611,7 +736,7 @@ void menu_gui(void) ui_font_face( &vgf_default_large ); list[1] -= 8; - menu_heading( list, "Controls" ); + menu_heading( list, "Controls", 0 ); if( menu_button( list, *row == 0, "Skating \xb2" ) ) { } @@ -619,7 +744,7 @@ void menu_gui(void) { } - menu_heading( list, "Workshop" ); + menu_heading( list, "Workshop", 0 ); if( menu_button( list, *row == 2, "Create a Board \xb2" ) ) { }