119 lines
2.9 KiB
Python
119 lines
2.9 KiB
Python
# Copyright (c) Twisted Matrix Laboratories.
|
|
# See LICENSE for details.
|
|
"""
|
|
Positioning interfaces.
|
|
|
|
@since: 14.0
|
|
"""
|
|
from zope.interface import Attribute, Interface
|
|
|
|
|
|
class IPositioningReceiver(Interface):
|
|
"""
|
|
An interface for positioning providers.
|
|
"""
|
|
def positionReceived(latitude, longitude):
|
|
"""
|
|
Method called when a position is received.
|
|
|
|
@param latitude: The latitude of the received position.
|
|
@type latitude: L{twisted.positioning.base.Coordinate}
|
|
@param longitude: The longitude of the received position.
|
|
@type longitude: L{twisted.positioning.base.Coordinate}
|
|
"""
|
|
|
|
|
|
def positionErrorReceived(positionError):
|
|
"""
|
|
Method called when position error is received.
|
|
|
|
@param positioningError: The position error.
|
|
@type positioningError: L{twisted.positioning.base.PositionError}
|
|
"""
|
|
|
|
def timeReceived(time):
|
|
"""
|
|
Method called when time and date information arrives.
|
|
|
|
@param time: The date and time (expressed in UTC unless otherwise
|
|
specified).
|
|
@type time: L{datetime.datetime}
|
|
"""
|
|
|
|
|
|
def headingReceived(heading):
|
|
"""
|
|
Method called when a true heading is received.
|
|
|
|
@param heading: The heading.
|
|
@type heading: L{twisted.positioning.base.Heading}
|
|
"""
|
|
|
|
|
|
def altitudeReceived(altitude):
|
|
"""
|
|
Method called when an altitude is received.
|
|
|
|
@param altitude: The altitude.
|
|
@type altitude: L{twisted.positioning.base.Altitude}
|
|
"""
|
|
|
|
|
|
def speedReceived(speed):
|
|
"""
|
|
Method called when the speed is received.
|
|
|
|
@param speed: The speed of a mobile object.
|
|
@type speed: L{twisted.positioning.base.Speed}
|
|
"""
|
|
|
|
|
|
def climbReceived(climb):
|
|
"""
|
|
Method called when the climb is received.
|
|
|
|
@param climb: The climb of the mobile object.
|
|
@type climb: L{twisted.positioning.base.Climb}
|
|
"""
|
|
|
|
def beaconInformationReceived(beaconInformation):
|
|
"""
|
|
Method called when positioning beacon information is received.
|
|
|
|
@param beaconInformation: The beacon information.
|
|
@type beaconInformation: L{twisted.positioning.base.BeaconInformation}
|
|
"""
|
|
|
|
|
|
|
|
class IPositioningBeacon(Interface):
|
|
"""
|
|
A positioning beacon.
|
|
"""
|
|
identifier = Attribute(
|
|
"""
|
|
A unique identifier for this beacon. The type is dependant on the
|
|
implementation, but must be immutable.
|
|
""")
|
|
|
|
|
|
|
|
class INMEAReceiver(Interface):
|
|
"""
|
|
An object that can receive NMEA data.
|
|
"""
|
|
def sentenceReceived(sentence):
|
|
"""
|
|
Method called when a sentence is received.
|
|
|
|
@param sentence: The received NMEA sentence.
|
|
@type L{twisted.positioning.nmea.NMEASentence}
|
|
"""
|
|
|
|
|
|
|
|
__all__ = [
|
|
"IPositioningReceiver",
|
|
"IPositioningBeacon",
|
|
"INMEAReceiver"
|
|
]
|