#include "player.h"
#include "shaders/menu.h"
+#include "vg/vg_steam_friends.h"
VG_STATIC mdl_context menu_model;
VG_STATIC glmesh menu_glmesh;
menu_page = 0x2;
}
+
+VG_STATIC void steam_on_game_overlay( CallbackMsg_t *msg )
+{
+ GameOverlayActivated_t *inf = (GameOverlayActivated_t *)msg->m_pubParam;
+ vg_info( "Steam game overlay activated; pausing\n" );
+
+ if( inf->m_bActive )
+ {
+ cl_menu = 1;
+ menu_page = 1;
+ }
+}
+
VG_STATIC void menu_init(void)
{
vg_linear_clear( vg_mem.scratch );
}
shader_menu_register();
+
+#ifdef SR_NETWORKED
+ steam_register_callback( k_iGameOverlayActivated, steam_on_game_overlay );
+#endif
}
VG_STATIC void menu_run_directional(void)
world_routes_debug();
#endif
- int closest = 0;
- float min_dist = INFINITY;
-
- for( int i=0; i<world.route_count; i++ )
+ if( world.route_count > 0 )
{
- float d = v3_dist2( world.routes[i].scoreboard_transform[3], pos );
+ int closest = 0;
+ float min_dist = INFINITY;
- if( d < min_dist )
+ for( int i=0; i<world.route_count; i++ )
{
- min_dist = d;
- closest = i;
- }
- }
+ float d = v3_dist2( world.routes[i].scoreboard_transform[3], pos );
- if( (world.active_route_board != closest) || network_scores_updated )
- {
- network_scores_updated = 0;
- world.active_route_board = closest;
+ if( d < min_dist )
+ {
+ min_dist = d;
+ closest = i;
+ }
+ }
- struct route *route = &world.routes[closest];
+ if( (world.active_route_board != closest) || network_scores_updated )
+ {
+ network_scores_updated = 0;
+ world.active_route_board = closest;
- u32 id = route->track_id;
+ struct route *route = &world.routes[closest];
- if( id != 0xffffffff )
- {
- struct netmsg_board *local_board = &scoreboard_client_data.boards[id];
+ u32 id = route->track_id;
- for( int i=0; i<13; i++ )
+ if( id != 0xffffffff )
{
- sfd_encode( i, &local_board->data[27*i] );
+ struct netmsg_board *local_board =
+ &scoreboard_client_data.boards[id];
+
+ for( int i=0; i<13; i++ )
+ {
+ sfd_encode( i, &local_board->data[27*i] );
+ }
}
}
}