Package org.goplanit.utils.zoning
Interface Connectoid
- 
- All Superinterfaces:
- Cloneable,- Comparable<IdAble>,- ExternalIdAble,- IdAble,- Iterable<Zone>,- ManagedId
 - All Known Subinterfaces:
- DirectedConnectoid,- UndirectedConnectoid
 - All Known Implementing Classes:
- ConnectoidImpl,- DirectedConnectoidImpl,- UndirectedConnectoidImpl
 
 public interface Connectoid extends ExternalIdAble, ManagedId, Iterable<Zone> the connecting component between zone(s) and the network. Note that connectoids are not vertices, they merely refer to physical entities via derived interfaces and the physical network.Each combintation of (zone,connectoid) can have additional properties such as length or allowed modes. Not specifying thos will cause the use of defaults (DEFAULT_LENGTH_KM, all modes allowed) - Author:
- markr
 
- 
- 
Field SummaryFields Modifier and Type Field Description static Class<Connectoid>CONNECTOID_ID_CLASSthe class ot use for id generationstatic ConnectoidTypeDEFAULT_CONNECTOID_TYPEdefault type is set to nonestatic doubleDEFAULT_LENGTH_KMDefault connectoid length in km
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description ZoneaddAccessZone(Zone zone)Add an access zone with default propertiesvoidaddAllowedMode(Zone zone, Mode allowedMode)Add an allowed mode.default voidaddAllowedModes(TransferZone transferZone, Set<Mode> allowedModes)Add allowed modes.default voidaddAllowedModes(Zone zone, Mode... allowedModes)Add allowed modes.DirectedVertexgetAccessVertex()collect the access vertex for this connectoidCollection<Zone>getAccessZones()The zones that can be accessed by this connectoidCollection<Mode>getExplicitlyAllowedModes(Zone accessZone)collect modes that are explicitly allowed for this zone (unmodifiable).ZonegetFirstAccessZone()first available zone that is accessible based on the first entry the iterator returnsdefault Class<Connectoid>getIdClass()Each managed id class is expected to generate its ids based on its class signature.Optional<Double>getLengthKm(Zone accessZone)length can be used to virtually assign a length to the connectoid/zone combinationStringgetName()The name of the connectoidlonggetNumberOfAccessZones()the number of accessible zones registeredConnectoidTypegetType()The type of the connectoidbooleanhasAccessZone(Zone accessZone)Check if zone is registered as access zonedefault booleanhasAccessZones()Verify if access zones are registereddefault booleanhasExplicitlyAllowedModes(Zone accessZone)Verify if any modes are allowed for this zonedefault booleanhasLength(Zone accessZone)Verify if a length has been specified for the access zone to connectoid combinationdefault booleanhasName()Verify if the connectoid has a namedefault booleanisAllModesAllowed(Zone accessZone)Verify if all modes are allowed for this zonebooleanisModeAllowed(Zone accessZone, Mode mode)Verify if a mode is allowed access to the zone via this connectoidvoidsetLength(Zone zone, double length)Add an access zone and provide length to this connectoidvoidsetName(String name)Set the name of the connectoidvoidsetType(ConnectoidType type)Set the type of the connectoid- 
Methods inherited from interface org.goplanit.utils.id.ExternalIdAblegetExternalId, getXmlId, hasExternalId, hasXmlId, setExternalId, setXmlId
 - 
Methods inherited from interface org.goplanit.utils.id.IdAbleclone, compareTo, getId, idEquals, idHashCode
 - 
Methods inherited from interface java.lang.IterableforEach, iterator, spliterator
 - 
Methods inherited from interface org.goplanit.utils.id.ManagedIdrecreateManagedIds, resetChildManagedIdEntities
 
- 
 
- 
- 
- 
Field Detail- 
CONNECTOID_ID_CLASSstatic final Class<Connectoid> CONNECTOID_ID_CLASS the class ot use for id generation
 - 
DEFAULT_LENGTH_KMstatic final double DEFAULT_LENGTH_KM Default connectoid length in km- See Also:
- Constant Field Values
 
 - 
DEFAULT_CONNECTOID_TYPEstatic final ConnectoidType DEFAULT_CONNECTOID_TYPE default type is set to none
 
- 
 - 
Method Detail- 
setNamevoid setName(String name) Set the name of the connectoid- Parameters:
- name- its name
 
 - 
getNameString getName() The name of the connectoid- Returns:
- its name
 
 - 
setTypevoid setType(ConnectoidType type) Set the type of the connectoid- Parameters:
- type- its type
 
 - 
getTypeConnectoidType getType() The type of the connectoid- Returns:
- its type
 
 - 
getAccessZonesCollection<Zone> getAccessZones() The zones that can be accessed by this connectoid- Returns:
- accessible zones
 
 - 
setLengthvoid setLength(Zone zone, double length) Add an access zone and provide length to this connectoid- Parameters:
- zone- to set length for
- length- to traverse between connectoid and zone
 
 - 
addAllowedModevoid addAllowedMode(Zone zone, Mode allowedMode) Add an allowed mode. We assume the zone is already registered as an access zone for this connectoid- Parameters:
- zone- to add allowed mode to
- allowedMode- to add
 
 - 
addAccessZoneZone addAccessZone(Zone zone) Add an access zone with default properties- Parameters:
- zone- to register as accessible
- Returns:
- overwritten zone if any
 
 - 
hasAccessZoneboolean hasAccessZone(Zone accessZone) Check if zone is registered as access zone- Parameters:
- accessZone- to verify
- Returns:
- true when registered, false otherwise
 
 - 
getFirstAccessZoneZone getFirstAccessZone() first available zone that is accessible based on the first entry the iterator returns- Returns:
- first available zone
 
 - 
getNumberOfAccessZoneslong getNumberOfAccessZones() the number of accessible zones registered- Returns:
- number of accessible zones
 
 - 
getLengthKmOptional<Double> getLengthKm(Zone accessZone) throws PlanItException length can be used to virtually assign a length to the connectoid/zone combination- Parameters:
- accessZone- to collect length for
- Returns:
- length in km(null if zone is not registered)
- Throws:
- PlanItException- thrown if error
 
 - 
isModeAllowedboolean isModeAllowed(Zone accessZone, Mode mode) throws PlanItException Verify if a mode is allowed access to the zone via this connectoid- Parameters:
- accessZone- to verify
- mode- to verify if allowed
- Returns:
- true when allowed, false otherwise
- Throws:
- PlanItException- thrown if provided zone is not valid
 
 - 
getExplicitlyAllowedModesCollection<Mode> getExplicitlyAllowedModes(Zone accessZone) collect modes that are explicitly allowed for this zone (unmodifiable). Note that if no explicit allowed modes are present, all modes are implicitly allowed. When there exist explicitly allowed modes, any mdoes in the network not included in the explicitly allowed modes are regarded to not be allowed.- Parameters:
- accessZone- to check
- Returns:
- the modes explicitly allowed for this zone, null if none
 
 - 
getAccessVertexDirectedVertex getAccessVertex() collect the access vertex for this connectoid- Returns:
- access vertex
 
 - 
getIdClassdefault Class<Connectoid> getIdClass() Each managed id class is expected to generate its ids based on its class signature. To be able to generate the correct id the class used for id generation is to be provided via this method call.- Specified by:
- getIdClassin interface- ManagedId
- Returns:
- idClass to use for generating ids for instances of this idable derived class
 
 - 
hasNamedefault boolean hasName() Verify if the connectoid has a name- Returns:
- true when present false otherwise
 
 - 
addAllowedModesdefault void addAllowedModes(Zone zone, Mode... allowedModes) Add allowed modes. We assume the zone is already registered as an access zone for this connectoid- Parameters:
- zone- to add allowed mode(s) to
- allowedModes- to add
 
 - 
addAllowedModesdefault void addAllowedModes(TransferZone transferZone, Set<Mode> allowedModes) Add allowed modes. We assume the zone is already registered as an access zone for this connectoid- Parameters:
- transferZone- to add allowed mode(s) to
- allowedModes- to add
 
 - 
hasExplicitlyAllowedModesdefault boolean hasExplicitlyAllowedModes(Zone accessZone) Verify if any modes are allowed for this zone- Parameters:
- accessZone- to check
- Returns:
- true when at least one mode is allowed, false otherwise
 
 - 
isAllModesAlloweddefault boolean isAllModesAllowed(Zone accessZone) Verify if all modes are allowed for this zone- Parameters:
- accessZone- to check
- Returns:
- true when we know for certain all modes are allowed, false otherwise
 
 - 
hasLengthdefault boolean hasLength(Zone accessZone) Verify if a length has been specified for the access zone to connectoid combination- Parameters:
- accessZone- to verify
- Returns:
- true if present, false otherwise
 
 - 
hasAccessZonesdefault boolean hasAccessZones() Verify if access zones are registered- Returns:
- true when present, false otherwise
 
 
- 
 
-