- java.lang.Object
-
- org.arakhne.afc.gis.primitive.AbstractGISElement<C,T>
-
- org.arakhne.afc.gis.primitive.AbstractBoundedGISElement<GISLayerContainer<?>,MapLayer>
-
- org.arakhne.afc.gis.maplayer.MapLayer
-
- org.arakhne.afc.gis.maplayer.MultiMapLayer<BusLineLayer>
-
- org.arakhne.afc.gis.bus.layer.BusNetworkLayer
-
- All Implemented Interfaces:
Serializable
,Cloneable
,Iterable<BusLineLayer>
,EventListener
,AttributeChangeListener
,AttributeCollection
,AttributeProvider
,BusLayer
,GISLayerContainer<BusLineLayer>
,BoundedGISElement
,GISBrowsable
,GISCloneable<MapLayer>
,GISContainer<BusLineLayer>
,GISContentElement<GISLayerContainer<?>>
,GISEditable
,GISElement
,GISPrimitive
,GISTreeBrowsable<BusLineLayer>
,BoundedElement2afp<Rectangle2d>
,InformedIterable<BusLineLayer>
,JsonableObject
public class BusNetworkLayer extends MultiMapLayer<BusLineLayer> implements BusLayer
This class permits to display a bus network.- Since:
- 14.0
- Version:
- 17.0 2020-01-04 14:41:56
- Author:
- Stéphane GALLAND
- See Also:
- Serialized Form
- Maven Group Id:
- org.arakhne.afc.gis
- Maven Artifact Id:
- gisbus
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.arakhne.afc.gis.maplayer.MapLayer
MapLayer.SpecialAttributeValue
-
-
Field Summary
-
Fields inherited from class org.arakhne.afc.gis.maplayer.MapLayer
ATTR_CLICKABLE, ATTR_COLOR, ATTR_REMOVABLE, ATTR_USE_CONTAINER_COLOR, ATTR_VISIBLE, listeners
-
Fields inherited from interface org.arakhne.afc.gis.primitive.GISElement
ATTR_NAME, NAME_COMPARATOR
-
Fields inherited from interface org.arakhne.afc.gis.primitive.GISPrimitive
COMPARATOR
-
-
Constructor Summary
Constructors Constructor Description BusNetworkLayer(UUID id, AttributeCollection attributeProvider, BusNetwork network)
Create a new layer.BusNetworkLayer(UUID id, AttributeCollection attributeProvider, BusNetwork network, boolean autoUpdate)
Create a new layer.BusNetworkLayer(UUID id, BusNetwork network)
Create a new layer.BusNetworkLayer(UUID id, BusNetwork network, boolean autoUpdate)
Create a new layer.BusNetworkLayer(AttributeCollection attributeProvider, BusNetwork network)
Create a new layer.BusNetworkLayer(AttributeCollection attributeProvider, BusNetwork network, boolean autoUpdate)
Create a new layer.BusNetworkLayer(BusNetwork network)
Create a new layer.BusNetworkLayer(BusNetwork network, boolean autoUpdate)
Create a new layer.
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description protected Rectangle2d
calcBounds()
Compute the bounds of this element.protected void
finalize()
Deprecated, for removal: This API element is subject to removal in a future version.protected void
fireBusNetworkChanged()
Send an event to notify listeners that the bus network has changed.BusNetwork
getBusNetwork()
Replies the bus network displayed by this layer.int
getColor()
Replies the color of this element or the color of the container.BusPrimitiveInvalidity
getInvalidityReason()
Replies the explanation of the invalidity of the primitive.String
getName()
Replies the name of the element.Integer
getRawColor()
Replies the color stored inside this element.Shape2d<?>
getShape()
Replies the shape of this this element.protected void
initializeElements()
Run the initialization of the elements from the current bus line.boolean
isLayerAutoUpdated()
Replies if this layer is automatically updated when a bus itinerary was removed or added.boolean
isValidLayer()
Replies if this layer and its content is marked as valid.protected boolean
onAllBusLineRemoved()
Invoked when all the bus lines were removed from the attached network.protected boolean
onBusLineAdded(BusLine line, int index)
Invoked when a bus line was added in the attached network.protected boolean
onBusLineChanged(BusLine line, int index)
Invoked when a bus line was changed in the attached network.protected boolean
onBusLineRemoved(BusLine line, int index)
Invoked when a bus line was removed from the attached network.void
resetBoundingBox()
Clear the current bounding box to force the computation of it at the next call toAbstractBoundedGISElement.getBoundingBox()
.void
revalidate()
Check if the validity of this layer is correctly set and change its values if necessary.void
setColor(int color)
Set the color of this element.void
setLayerAutoUpdated(boolean update)
Set if this layer is automatically updated when a bus itinerary was removed or added.void
setName(String name)
Set the name of the element.void
toJson(JsonBuffer buffer)
Replies the Json representation of this node.-
Methods inherited from class org.arakhne.afc.gis.maplayer.MultiMapLayer
addMapLayer, addMapLayer, bindChangeListener, calcVisibleBounds, clear, clone, fireElementChanged, fireLayerAddedEvent, fireLayerAttributeChangedEvent, fireLayerContentChangedEvent, fireLayerHierarchyChangedEvent, fireLayerMovedDownEvent, fireLayerMovedUpEvent, fireLayerRemoveAllEvent, fireLayerRemovedEvent, getAllMapLayers, getBottomUpIterator, getChildAt, getChildCount, getElementType, getMapLayerAt, getMapLayerCount, getParent, getTopDownIterator, getVisibleBoundingBox, indexOf, isBottomLayer, isTopLayer, iterator, moveLayerDown, moveLayerDown, moveLayerUp, moveLayerUp, onAttributeChangeEvent, removeMapLayer, removeMapLayerAt, reverseIterator, setMapLayerAt, size
-
Methods inherited from class org.arakhne.afc.gis.maplayer.MapLayer
addGISEditableChangeListener, addLayerListener, contains, contains, fireLayerAttributeChangedEvent, getGeoLocation, getListeners, getParentName, indexInParent, intersects, isClickable, isContainerColorUsed, isReadOnlyObject, isRemovable, isTemporaryLayer, isVisible, removeGISEditableChangeListener, removeLayerListener, repaint, setClickable, setContainer, setContainerColorUse, setReadOnlyObject, setRemovable, setUUID, setVisible, setVisible
-
Methods inherited from class org.arakhne.afc.gis.primitive.AbstractBoundedGISElement
getBoundingBox, setBoundingBox
-
Methods inherited from class org.arakhne.afc.gis.primitive.AbstractGISElement
addAttributeChangeListener, addAttributes, addAttributes, attributes, copyAttributes, flush, freeMemory, getAllAttributeNames, getAllAttributes, getAllAttributesByType, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttributeAsBool, getAttributeAsDate, getAttributeAsDouble, getAttributeAsEnumeration, getAttributeAsEnumeration, getAttributeAsFloat, getAttributeAsInetAddress, getAttributeAsInt, getAttributeAsJavaClass, getAttributeAsLong, getAttributeAsString, getAttributeAsURI, getAttributeAsURL, getAttributeAsUUID, getAttributeCollection, getAttributeCount, getAttributeObject, getAttributeProvider, getContainer, getGeoId, getTopContainer, getUUID, hasAttribute, hashKey, isEventFirable, removeAllAttributes, removeAttribute, removeAttributeChangeListener, renameAttribute, renameAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttributes, setAttributes, setAttributeType, setEventFirable, toMap, toMap, toString
-
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.arakhne.afc.attrs.collection.AttributeCollection
addAttributeChangeListener, addAttributes, addAttributes, flush, isEventFirable, removeAllAttributes, removeAttribute, removeAttributeChangeListener, renameAttribute, renameAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttributes, setAttributes, setAttributeType, setEventFirable
-
Methods inherited from interface org.arakhne.afc.attrs.collection.AttributeProvider
attributes, freeMemory, getAllAttributeNames, getAllAttributes, getAllAttributesByType, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttribute, getAttributeAsBool, getAttributeAsDate, getAttributeAsDouble, getAttributeAsEnumeration, getAttributeAsEnumeration, getAttributeAsFloat, getAttributeAsInetAddress, getAttributeAsInt, getAttributeAsJavaClass, getAttributeAsLong, getAttributeAsString, getAttributeAsURI, getAttributeAsURL, getAttributeAsUUID, getAttributeCount, getAttributeObject, hasAttribute, toMap, toMap
-
Methods inherited from interface org.arakhne.afc.math.geometry.d2.afp.BoundedElement2afp
getBoundingBox
-
Methods inherited from interface org.arakhne.afc.gis.primitive.GISBrowsable
getParentName, isVisible, setVisible, setVisible
-
Methods inherited from interface org.arakhne.afc.gis.primitive.GISContentElement
getContainer, getTopContainer
-
Methods inherited from interface org.arakhne.afc.gis.primitive.GISElement
copyAttributes, hashKey
-
Methods inherited from interface org.arakhne.afc.gis.maplayer.GISLayerContainer
addLayerListener, removeLayerListener
-
Methods inherited from interface org.arakhne.afc.gis.primitive.GISPrimitive
getGeoId, getGeoLocation, getUUID
-
Methods inherited from interface java.lang.Iterable
forEach, spliterator
-
-
-
-
Constructor Detail
-
BusNetworkLayer
public BusNetworkLayer(BusNetwork network)
Create a new layer.- Parameters:
network
- is the embedded network
-
BusNetworkLayer
public BusNetworkLayer(BusNetwork network, boolean autoUpdate)
Create a new layer.- Parameters:
network
- is the embedded networkautoUpdate
- indicates if this bus network should be automatically updated when a bus line as changed.- Since:
- 4.0
-
BusNetworkLayer
public BusNetworkLayer(UUID id, BusNetwork network)
Create a new layer.- Parameters:
id
- is the unique identifier of this element, ornull
if unknown.network
- is the embedded network- Since:
- 4.0
-
BusNetworkLayer
public BusNetworkLayer(UUID id, BusNetwork network, boolean autoUpdate)
Create a new layer.- Parameters:
id
- is the unique identifier of this element, ornull
if unknown.network
- is the embedded networkautoUpdate
- indicates if this bus network should be automatically updated when a bus line as changed.- Since:
- 4.0
-
BusNetworkLayer
public BusNetworkLayer(AttributeCollection attributeProvider, BusNetwork network)
Create a new layer.- Parameters:
attributeProvider
- is the attribute collection associated to this layer.network
- is the embedded network
-
BusNetworkLayer
public BusNetworkLayer(AttributeCollection attributeProvider, BusNetwork network, boolean autoUpdate)
Create a new layer.- Parameters:
attributeProvider
- is the attribute collection associated to this layer.network
- is the embedded networkautoUpdate
- indicates if this bus network should be automatically updated when a bus line as changed.- Since:
- 4.0
-
BusNetworkLayer
public BusNetworkLayer(UUID id, AttributeCollection attributeProvider, BusNetwork network)
Create a new layer.- Parameters:
id
- is the unique identifier of this element, ornull
if unknown.attributeProvider
- is the attribute collection associated to this layer.network
- is the embedded network- Since:
- 4.0
-
BusNetworkLayer
public BusNetworkLayer(UUID id, AttributeCollection attributeProvider, BusNetwork network, boolean autoUpdate)
Create a new layer.- Parameters:
id
- is the unique identifier of this element, ornull
if unknown.attributeProvider
- is the attribute collection associated to this layer.network
- is the embedded networkautoUpdate
- indicates if this bus network should be automatically updated when a bus line as changed.- Since:
- 4.0
-
-
Method Detail
-
toJson
@Pure public void toJson(JsonBuffer buffer)
Description copied from interface:JsonableObject
Replies the Json representation of this node.- Specified by:
toJson
in interfaceJsonableObject
- Overrides:
toJson
in classMultiMapLayer<BusLineLayer>
- Parameters:
buffer
- the Json buffer.
-
finalize
@Deprecated(since="17.0", forRemoval=true) protected void finalize() throws Throwable
Deprecated, for removal: This API element is subject to removal in a future version.
-
initializeElements
protected void initializeElements()
Run the initialization of the elements from the current bus line.This function is invoked by the constructor of BusLineLayer if its parameter autoUpdate is
true
, and not invoked if this parameter isfalse
.
-
onBusLineAdded
protected boolean onBusLineAdded(BusLine line, int index)
Invoked when a bus line was added in the attached network.This function exists to allow be override to provide a specific behaviour when a bus line has been added.
- Parameters:
line
- is the new line.index
- is the index of the bus line.- Returns:
true
if the events was fired, otherwisefalse
.
-
onBusLineRemoved
protected boolean onBusLineRemoved(BusLine line, int index)
Invoked when a bus line was removed from the attached network.This function exists to allow be override to provide a specific behaviour when a bus line has been removed.
- Parameters:
line
- is the removed line.index
- is the index of the bus line.- Returns:
true
if the events was fired, otherwisefalse
.
-
onAllBusLineRemoved
protected boolean onAllBusLineRemoved()
Invoked when all the bus lines were removed from the attached network.This function exists to allow be override to provide a specific behaviour when a bus line has been removed.
- Returns:
true
if the events was fired, otherwisefalse
.
-
onBusLineChanged
protected boolean onBusLineChanged(BusLine line, int index)
Invoked when a bus line was changed in the attached network.This function exists to allow be override to provide a specific behaviour when a bus line has changed.
- Parameters:
line
- is the changed line.index
- is the index of the bus line.- Returns:
true
if the events was fired, otherwisefalse
.
-
fireBusNetworkChanged
protected void fireBusNetworkChanged()
Send an event to notify listeners that the bus network has changed.
-
isLayerAutoUpdated
public boolean isLayerAutoUpdated()
Replies if this layer is automatically updated when a bus itinerary was removed or added.- Returns:
true
if the layer is automatically updated,false
.
-
setLayerAutoUpdated
public void setLayerAutoUpdated(boolean update)
Set if this layer is automatically updated when a bus itinerary was removed or added.- Parameters:
update
- istrue
if the layer should be automatically updated,false
.
-
getName
public String getName()
Description copied from interface:GISElement
Replies the name of the element.- Specified by:
getName
in interfaceGISContainer<BusLineLayer>
- Specified by:
getName
in interfaceGISEditable
- Specified by:
getName
in interfaceGISElement
- Overrides:
getName
in classAbstractGISElement<GISLayerContainer<?>,MapLayer>
- Returns:
- the name
-
getRawColor
public Integer getRawColor()
Description copied from interface:GISEditable
Replies the color stored inside this element.- Specified by:
getRawColor
in interfaceGISEditable
- Overrides:
getRawColor
in classMapLayer
- Returns:
- the color of this element, or
null
.
-
getColor
public int getColor()
Description copied from interface:GISEditable
Replies the color of this element or the color of the container.- Specified by:
getColor
in interfaceGISContainer<BusLineLayer>
- Specified by:
getColor
in interfaceGISEditable
- Overrides:
getColor
in classMapLayer
- Returns:
- the color.
- See Also:
GISEditable.getRawColor()
-
setName
public void setName(String name)
Description copied from interface:GISElement
Set the name of the element.- Specified by:
setName
in interfaceGISBrowsable
- Specified by:
setName
in interfaceGISEditable
- Specified by:
setName
in interfaceGISElement
- Overrides:
setName
in classAbstractGISElement<GISLayerContainer<?>,MapLayer>
- Parameters:
name
- the new name.
-
setColor
public void setColor(int color)
Description copied from interface:GISBrowsable
Set the color of this element.- Specified by:
setColor
in interfaceGISBrowsable
- Specified by:
setColor
in interfaceGISEditable
- Overrides:
setColor
in classMapLayer
- Parameters:
color
- the new color.
-
calcBounds
protected Rectangle2d calcBounds()
Description copied from class:AbstractBoundedGISElement
Compute the bounds of this element. This function does not update the internal attribute replied byAbstractBoundedGISElement.getBoundingBox()
- Overrides:
calcBounds
in classMultiMapLayer<BusLineLayer>
- Returns:
- the bounds
-
getShape
public Shape2d<?> getShape()
Description copied from interface:BoundedGISElement
Replies the shape of this this element.The bounding box replied by
BoundedElement2afp.getBoundingBox()
encloses the replied shape.- Specified by:
getShape
in interfaceBoundedGISElement
- Overrides:
getShape
in classMultiMapLayer<BusLineLayer>
- Returns:
- the shape or
null
if not applicable.
-
resetBoundingBox
public void resetBoundingBox()
Description copied from class:MapLayer
Clear the current bounding box to force the computation of it at the next call toAbstractBoundedGISElement.getBoundingBox()
.- Specified by:
resetBoundingBox
in interfaceBoundedGISElement
- Specified by:
resetBoundingBox
in interfaceGISContainer<BusLineLayer>
- Overrides:
resetBoundingBox
in classMultiMapLayer<BusLineLayer>
-
getBusNetwork
public BusNetwork getBusNetwork()
Replies the bus network displayed by this layer.- Returns:
- the bus network displayed by this layer.
-
isValidLayer
public boolean isValidLayer()
Description copied from interface:BusLayer
Replies if this layer and its content is marked as valid.The validity of a bus primitive depends on the type of this primitive. Please refers to the documentation of that primitive.
- Specified by:
isValidLayer
in interfaceBusLayer
- Returns:
true
if the layer is valid, otherwisefalse
-
getInvalidityReason
public BusPrimitiveInvalidity getInvalidityReason()
Description copied from interface:BusLayer
Replies the explanation of the invalidity of the primitive.- Specified by:
getInvalidityReason
in interfaceBusLayer
- Returns:
- the invalidity reason.
-
revalidate
public void revalidate()
Description copied from interface:BusLayer
Check if the validity of this layer is correctly set and change its values if necessary. This function revalidate also all the layers and primitives inside this layer.- Specified by:
revalidate
in interfaceBusLayer
-
-