Add some challenges to the world map
[carveJwlIkooP6JGAAIwe30JlM.git] / menu.c
diff --git a/menu.c b/menu.c
index daeb61a2b6057ce7c3d7422c1f03edd9c236d3f6..eaec9073b699137a47942f143c3301bb4dbe92ee 100644 (file)
--- 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; i<mdl_arrcount( &world->ent_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; j<mdl_arrcount(&world->ent_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; j<mdl_arrcount(&world->ent_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" ) )
          {
          }