1
0
mirror of https://github.com/JezuzLizard/BO2-Reimagined.git synced 2025-06-11 23:57:59 -05:00

Grief: round restart optimizations

This commit is contained in:
Jbleezy
2021-12-18 02:55:27 -08:00
parent 3f813b7c35
commit e6d13e64b8
2 changed files with 118 additions and 81 deletions

View File

@ -377,6 +377,8 @@ headstomp_watcher()
round_start_wait(time, initial)
{
level endon("end_game");
if(!isDefined(initial))
{
initial = false;
@ -509,6 +511,9 @@ countdown_pulse( hud_elem, duration )
zombie_spawn_wait(time)
{
level endon("end_game");
level endon( "restart_round" );
flag_clear("spawn_zombies");
wait time;

View File

@ -8,6 +8,7 @@ wait_for_team_death_and_round_end()
level endon( "end_game" );
checking_for_round_end = 0;
checking_for_round_tie = 0;
level.isresetting_grief = 0;
while ( 1 )
{
@ -42,16 +43,40 @@ wait_for_team_death_and_round_end()
i++;
}
if ( cia_total == 0 )
{
level notify( "stop_round_end_check" );
level thread round_end( "B", true );
checking_for_round_end = 1;
}
else if ( cdc_total == 0 )
{
level notify( "stop_round_end_check" );
level thread round_end( "A", true );
checking_for_round_end = 1;
}
if ( !checking_for_round_tie )
{
if(cia_alive == 0 && cdc_alive == 0)
{
level notify( "stop_round_end_check" );
level thread check_for_round_end();
checking_for_round_tie = 1;
checking_for_round_end = 1;
}
}
if ( !checking_for_round_end )
{
if ( cia_alive == 0 )
{
level thread round_end( "B", cia_total == 0 );
level thread check_for_round_end( "B" );
checking_for_round_end = 1;
}
else if ( cdc_alive == 0 )
{
level thread round_end( "A", cdc_total == 0 );
level thread check_for_round_end( "A" );
checking_for_round_end = 1;
}
}
@ -60,12 +85,29 @@ wait_for_team_death_and_round_end()
{
level notify( "stop_round_end_check" );
checking_for_round_end = 0;
checking_for_round_tie = 0;
}
wait 0.05;
}
}
check_for_round_end(winner)
{
level endon( "stop_round_end_check" );
if(isDefined(winner))
{
wait 5;
}
else
{
wait 0.5;
}
level thread round_end(winner);
}
round_end(winner, force_win)
{
if(!isDefined(force_win))
@ -73,34 +115,24 @@ round_end(winner, force_win)
force_win = false;
}
winner_alive = 0;
team = undefined;
if(isDefined(winner))
{
if(winner == "A")
{
team = "axis";
if(winner == "B")
}
else
{
team = "allies";
}
if(!force_win)
{
wait 5;
}
players = get_players();
foreach(player in players)
{
if(is_player_valid(player) && player.team == team)
{
winner_alive = 1;
break;
}
}
if(winner_alive)
if(isDefined(winner))
{
level.grief_score[winner]++;
level.grief_hud.score[team] setValue(level.grief_score[winner]);
setteamscore(team, level.grief_score[winner]);
}
if(level.grief_score[winner] == level.grief_winning_score || force_win)
{
@ -124,9 +156,10 @@ round_end(winner, force_win)
level._game_module_game_end_check = undefined;
maps/mp/gametypes_zm/_zm_gametype::track_encounters_win_stats( level.gamemodulewinningteam );
level notify( "end_game" );
return;
}
else
{
}
players = get_players();
foreach(player in players)
{
@ -152,7 +185,7 @@ round_end(winner, force_win)
setroundsplayed(level.round_number);
level thread maps/mp/zombies/_zm_audio_announcer::leaderdialog( "grief_restarted" );
if(winner_alive)
if(isDefined(winner))
{
foreach(player in players)
{
@ -177,7 +210,6 @@ round_end(winner, force_win)
zombie_goto_round( level.round_number );
level thread maps/mp/zombies/_zm_game_module::reset_grief();
level thread maps/mp/zombies/_zm::round_think( 1 );
}
}
zombie_goto_round(target_round)