-
Notifications
You must be signed in to change notification settings - Fork 3
4. The FlightContextFactory
The FlightContextFactory
object is a factory wrapper around the FlightContext
object. This specific wrapper will make your life easier when you have to process position information from multiple different aircraft at the same time.
To create a basic FlightContextFactory
instance you can immediately use for flight processing:
FlightContextFactory factory = new FlightContextFactory();
Why would you want to use the FlightContextFactory
over the FlightContext
object?
The FlightContextFactory
object will instantiate a new FlightContext
object for you each time information from a new aircraft is being detected. In order for this to work it is required that you use the aircraftId
field on the PositionUpdate
object to identify different aircraft! The FlightContextFactory
will also clean up old information from aircraft which have been gone for a while in order to prevent high memory usage. Besides this the object subscribes to all events on each individual FlightContext
instance and propagates them through the events available on the FlightContextFactory
object so you will have a single endpoint to retrieve information for all different aircraft you're tracking.
These events are available on the FlightContextFactory
object:
-
OnTakeoff
; when the aircraft being tracked has taken off. -
OnLanding
; when the aircraft being tracked has landed. -
OnRadarContact
; will fire when a previously unseen aircraft has been detected. -
CompletedWithErrors
; will fire when an aircraft was flying but a landing could not be detected within a reasonable timeframe. -
OnContextDispose
; please note this is the only event available on theFlightContextFactory
object which is not available on theFlightContext
! This event will fire when aFlightContext
has been disposed due to inactivity.
As the source from these events can be from an arbitrary FlightContext
instance under the hood all relevant flight (and aircraft) information will be available through the event args objects available on the events.
In order to keep track of multiple aircraft at the same time you can pass position information to the FlightContextFactory
as soon as you receive it! Again, the same principles as used with the FlightContext
are also being used here.
The FlightContextFactory
will automatically handle position information based on the aircraft id associated with the position update.
FlightContextFactory factory = new FlightContextFactory();
// It's completely up to you where you get this data from!
PositionUpdate positionUpdate = new PositionUpdate(.....);
factory.Enqueue(positionUpdate);
As soon as something interesting happens you will be informed by an event!
In order to process a collection of data you can just pass a collection of position updates to the FlightContextFactory
. It will take care of ordering the position updates by aircraft for you!
FlightContextFactory factory = new FlightContextFactory();
List<PositionUpdate> positionUpdates = new List<PositionUpdate>();
// I don't really care where you got this information from... Just fill the list!
factory.Enqueue(positionUpdates);
Again, when something exciting happens an event will keep you informed!