Class LaneFactory
java.lang.Object
org.opentrafficsim.road.network.factory.LaneFactory
 Copyright (c) 2013-2024 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. 
 BSD-style license. See OpenTrafficSim License.
 
- Author:
- Peter Knoppers
- 
Constructor SummaryConstructorsConstructorDescriptionLaneFactory(RoadNetwork network, Node from, Node to, LinkType type, OtsSimulatorInterface simulator, LaneKeepingPolicy policy, GtuType gtuType) LaneFactory(RoadNetwork network, Node from, Node to, LinkType type, OtsSimulatorInterface simulator, LaneKeepingPolicy policy, GtuType gtuType, ContinuousLine line) 
- 
Method SummaryModifier and TypeMethodDescriptionaddLanes(List<? super Stripe> stripeList, StripeData... types) Adds a lane pair for each stripe type, where the type determines the right-hand side stripe when building from left to right and vice versa.addLanes(StripeData... types) Adds a lane pair for each stripe type, where the type determines the right-hand side stripe when building from left to right and vice versa.addShoulder(org.djunits.value.vdouble.scalar.Length width, LateralDirectionality lat, LaneType laneType) Adds 1 or 2 shoulders to the current set of lanes.getLanes()Returns the created lanes in build order.leftToRight(double leftLanes, org.djunits.value.vdouble.scalar.Length laneWidth, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit) Prepare the factory to add lanes from left to right.static org.opentrafficsim.base.geometry.OtsLine2dmakeBezier(Node n1, Node n2, Node n3, Node n4) static LanemakeLane(RoadNetwork network, String name, Node from, Node to, org.djutils.draw.point.Point2d[] intermediatePoints, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit, OtsSimulatorInterface simulator, GtuType gtuType) Create a simple Lane.static CrossSectionLinkmakeLink(RoadNetwork network, String name, Node from, Node to, org.djutils.draw.point.Point2d[] intermediatePoints, OtsSimulatorInterface simulator) Create a Link along intermediate coordinates from one Node to another.static Lane[]makeMultiLane(RoadNetwork network, String name, Node from, Node to, org.djutils.draw.point.Point2d[] intermediatePoints, int laneCount, int laneOffsetAtStart, int laneOffsetAtEnd, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit, OtsSimulatorInterface simulator, GtuType gtuType) Create a simple road with the specified number of Lanes.
 This method returns an array of Lane.static Lane[]makeMultiLane(RoadNetwork network, String name, Node from, Node to, org.djutils.draw.point.Point2d[] intermediatePoints, int laneCount, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit, OtsSimulatorInterface simulator, GtuType gtuType) Create a simple road with the specified number of Lanes.
 This method returns an array of Lane.static Lane[]makeMultiLaneBezier(RoadNetwork network, String name, Node n1, Node n2, Node n3, Node n4, int laneCount, int laneOffsetAtStart, int laneOffsetAtEnd, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit, OtsSimulatorInterface simulator, GtuType gtuType) Create a simple road with the specified number of Lanes, based on a Bezier curve.
 This method returns an array of Lane.rightToLeft(double rightLanes, org.djunits.value.vdouble.scalar.Length laneWidth, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit) Prepare the factory to add lanes from right to left.setOffsetEnd(org.djunits.value.vdouble.scalar.Length endOffset) Set end offset.setOffsetStart(org.djunits.value.vdouble.scalar.Length startOffset) Set start offset.
- 
Constructor Details- 
LaneFactorypublic LaneFactory(RoadNetwork network, Node from, Node to, LinkType type, OtsSimulatorInterface simulator, LaneKeepingPolicy policy, GtuType gtuType) throws NetworkException - Parameters:
- network- network
- from- from node
- to- to node
- type- link type
- simulator- simulator
- policy- lane keeping policy
- gtuType- parent GTU type of relevant GTUs.
- Throws:
- NetworkException- if the link exists, or a node does not exist, in the network
 
- 
LaneFactorypublic LaneFactory(RoadNetwork network, Node from, Node to, LinkType type, OtsSimulatorInterface simulator, LaneKeepingPolicy policy, GtuType gtuType, ContinuousLine line) throws NetworkException - Parameters:
- network- network
- from- from node
- to- to node
- type- link type
- simulator- simulator
- policy- lane keeping policy
- gtuType- parent GTU type of relevant GTUs.
- line- line
- Throws:
- NetworkException- if the link exists, or a node does not exist, in the network
 
 
- 
- 
Method Details- 
leftToRightpublic LaneFactory leftToRight(double leftLanes, org.djunits.value.vdouble.scalar.Length laneWidth, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit) Prepare the factory to add lanes from left to right.- Parameters:
- leftLanes- number of lanes left from the link design line
- laneWidth- lane width
- laneType- lane type
- speedLimit- speed limit
- Returns:
- LaneFactory this lane factory for method chaining
 
- 
rightToLeftpublic LaneFactory rightToLeft(double rightLanes, org.djunits.value.vdouble.scalar.Length laneWidth, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit) Prepare the factory to add lanes from right to left.- Parameters:
- rightLanes- number of lanes right from the link design line
- laneWidth- lane width
- laneType- lane type
- speedLimit- speed limit
- Returns:
- LaneFactory this lane factory for method chaining
 
- 
setOffsetStartSet start offset.- Parameters:
- startOffset- offset
- Returns:
- LaneFactory this lane factory for method chaining
 
- 
setOffsetEndSet end offset.- Parameters:
- endOffset- offset
- Returns:
- LaneFactory this lane factory for method chaining
 
- 
addLanesAdds a lane pair for each stripe type, where the type determines the right-hand side stripe when building from left to right and vice versa. The left-most stripe is created inleftToRight(), meaning that each type describes permeablility between a lane and it's right-hand neighbor, when building left to right (and vice versa). This method internally addsSOLIDto create the final continuous stripe.- Parameters:
- types- type per lane pair, for N lanes N-1 should be provided
- Returns:
- this LaneFactory this lane factory for method chaining
 
- 
addLanesAdds a lane pair for each stripe type, where the type determines the right-hand side stripe when building from left to right and vice versa. The left-most stripe is created inleftToRight(), meaning that each type describes permeablility between a lane and it's right-hand neighbor, when building left to right (and vice versa). This method internally addsSOLIDto create the final continuous stripe. All generated stripes, including the one generated in leftToRight() or rightToLeft(), is returned in the provided list for custom permeability.- Parameters:
- stripeList- list in to which the generated stripes are placed.
- types- type per lane pair, for N lanes N-1 should be provided
- Returns:
- this LaneFactory this lane factory for method chaining
 
- 
addShoulderpublic LaneFactory addShoulder(org.djunits.value.vdouble.scalar.Length width, LateralDirectionality lat, LaneType laneType) Adds 1 or 2 shoulders to the current set of lanes.- Parameters:
- width- width of the shoulder
- lat- side of shoulder, use- nullor- NONEfor both
- laneType- lane type.
- Returns:
- LaneFactory this lane factory for method chaining
- Throws:
- IllegalStateException- if no lanes are defined
 
- 
getLanesReturns the created lanes in build order.- Returns:
- List<Lane> created lanes in build order
 
- 
makeLinkpublic static CrossSectionLink makeLink(RoadNetwork network, String name, Node from, Node to, org.djutils.draw.point.Point2d[] intermediatePoints, OtsSimulatorInterface simulator) throws NetworkException Create a Link along intermediate coordinates from one Node to another.- Parameters:
- network- the network
- name- name of the new Link
- from- start Node of the new Link
- to- end Node of the new Link
- intermediatePoints- array of intermediate coordinates (may be null in which case the node points are used)
- simulator- the simulator for this network
- Returns:
- the newly constructed Link
- Throws:
- NetworkException- if link already exists in the network, if name of the link is not unique, or if the start node or the end node of the link are not registered in the network.
 
- 
makeLanepublic static Lane makeLane(RoadNetwork network, String name, Node from, Node to, org.djutils.draw.point.Point2d[] intermediatePoints, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit, OtsSimulatorInterface simulator, GtuType gtuType) throws NetworkException Create a simple Lane.- Parameters:
- network- the network
- name- name of the Lane (and also of the Link that owns it)
- from- starting node of the new Lane
- to- ending node of the new Lane
- intermediatePoints- intermediate coordinates or null to create a straight road; the intermediate points may contain the coordinates of the from node and to node
- laneType- type of the new Lane
- speedLimit- the speed limit on the new Lane
- simulator- the simulator
- gtuType- parent GTU type of relevant GTUs
- Returns:
- the new Lane
- Throws:
- NetworkException- on network inconsistency
 
- 
makeMultiLanepublic static Lane[] makeMultiLane(RoadNetwork network, String name, Node from, Node to, org.djutils.draw.point.Point2d[] intermediatePoints, int laneCount, int laneOffsetAtStart, int laneOffsetAtEnd, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit, OtsSimulatorInterface simulator, GtuType gtuType) throws NetworkException Create a simple road with the specified number of Lanes.
 This method returns an array of Lane. These lanes are embedded in a Link that can be accessed through the getParentLink method of the Lane.- Parameters:
- network- the network
- name- name of the Link
- from- starting node of the new Lane
- to- ending node of the new Lane
- intermediatePoints- intermediate coordinates or null to create a straight road; the intermediate points may contain the coordinates of the from node and to node
- laneCount- number of lanes in the road
- laneOffsetAtStart- extra offset from design line in lane widths at start of link
- laneOffsetAtEnd- extra offset from design line in lane widths at end of link
- laneType- type of the new Lanes
- speedLimit- the speed limit on all lanes
- simulator- the simulator
- gtuType- parent GTU type of relevant GTUs
- Returns:
- array containing the new Lanes
- Throws:
- NetworkException- on topological problems
 
- 
makeMultiLanepublic static Lane[] makeMultiLane(RoadNetwork network, String name, Node from, Node to, org.djutils.draw.point.Point2d[] intermediatePoints, int laneCount, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit, OtsSimulatorInterface simulator, GtuType gtuType) throws NamingException, NetworkException Create a simple road with the specified number of Lanes.
 This method returns an array of Lane. These lanes are embedded in a Link that can be accessed through the getParentLink method of the Lane.- Parameters:
- network- the network
- name- name of the Link
- from- starting node of the new Lane
- to- ending node of the new Lane
- intermediatePoints- intermediate coordinates or null to create a straight road; the intermediate points may contain the coordinates of the from node and to node
- laneCount- number of lanes in the road
- laneType- type of the new Lanes
- speedLimit- Speed the speed limit (applies to all generated lanes)
- simulator- the simulator
- gtuType- parent GTU type of relevant GTUs
- Returns:
- array containing the new Lanes
- Throws:
- NamingException- when names cannot be registered for animation
- NetworkException- on topological problems
 
- 
makeMultiLaneBezierpublic static Lane[] makeMultiLaneBezier(RoadNetwork network, String name, Node n1, Node n2, Node n3, Node n4, int laneCount, int laneOffsetAtStart, int laneOffsetAtEnd, LaneType laneType, org.djunits.value.vdouble.scalar.Speed speedLimit, OtsSimulatorInterface simulator, GtuType gtuType) throws NamingException, NetworkException Create a simple road with the specified number of Lanes, based on a Bezier curve.
 This method returns an array of Lane. These lanes are embedded in a Link that can be accessed through the getParentLink method of the Lane.- Parameters:
- network- the network
- name- name of the Link
- n1- control node for the start direction
- n2- starting node of the new Lane
- n3- ending node of the new Lane
- n4- control node for the end direction
- laneCount- number of lanes in the road
- laneOffsetAtStart- extra offset from design line in lane widths at start of link
- laneOffsetAtEnd- extra offset from design line in lane widths at end of link
- laneType- type of the new Lanes
- speedLimit- the speed limit on all lanes
- simulator- the simulator
- gtuType- parent GTU type of relevant GTUs
- Returns:
- array containing the new Lanes
- Throws:
- NamingException- when names cannot be registered for animation
- NetworkException- on topological problems
 
- 
makeBezierpublic static org.opentrafficsim.base.geometry.OtsLine2d makeBezier(Node n1, Node n2, Node n3, Node n4) - Parameters:
- n1- node 1
- n2- node 2
- n3- node 3
- n4- node 4
- Returns:
- line between n2 and n3 with start-direction n1-->n2 and end-direction n3-->n4
 
 
-