# HG changeset patch # User celestar # Date 1170428699 0 # Node ID ec5a48f5ac640543057165710f18920af37c9423 # Parent 7c42887c768a3442a5f1bfe6429cf5b2185aa7ad (svn r8534) -Feature/Codechange: Provide aircraft with vertical separation depending on their altitude and velocity diff --git a/src/aircraft_cmd.cpp b/src/aircraft_cmd.cpp --- a/src/aircraft_cmd.cpp +++ b/src/aircraft_cmd.cpp @@ -898,14 +898,32 @@ return t < v->progress; } -// get Aircraft running altitude +/** + * Gets the cruise altitude of an aircraft. + * The cruise altitude is determined by the velocity of the vehicle + * and the direction it is moving + * @param v The vehicle. Should be an aircraft + * @returns Altitude in pixel units + */ static byte GetAircraftFlyingAltitude(const Vehicle *v) { - switch (v->max_speed) { - case 37: return 162; - case 74: return 171; - default: return 180; + /* Make sure Aircraft fly no lower so that they don't conduct + * CFITs (controlled flight into terrain) + */ + byte base_altitude = 150; + + /* Make sure eastbound and westbound planes do not "crash" into each + * other by providing them with vertical seperation + */ + switch (v->direction) { + case DIR_N: case DIR_NE: case DIR_E: case DIR_SE: base_altitude += 15; break; + default: break; } + + /* Make faster planes fly higher so that they can overtake slower ones */ + base_altitude += min(30 * (v->max_speed / 37), 90); + + return base_altitude; } static bool AircraftController(Vehicle *v)