Package org.locationtech.jts.noding
Class NodedSegmentString
- java.lang.Object
-
- org.locationtech.jts.noding.NodedSegmentString
-
- All Implemented Interfaces:
NodableSegmentString,SegmentString
public class NodedSegmentString extends Object implements NodableSegmentString
Represents a list of contiguous line segments, and supports noding the segments. The line segments are represented by an array ofCoordinates. Intended to optimize the noding of contiguous segments by reducing the number of allocated objects.SegmentStrings can carry a context object, which is useful for preserving topological or parentage information. All noded substrings are initialized with the same context object.For read-only applications use
BasicSegmentString, which is (slightly) more lightweight.- Version:
- 1.7
- See Also:
BasicSegmentString
-
-
Constructor Summary
Constructors Constructor Description NodedSegmentString(Coordinate[] pts, Object data)Creates a instance from a list of vertices and optional data object.NodedSegmentString(SegmentString ss)Creates a new instance from aSegmentString.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddIntersection(LineIntersector li, int segmentIndex, int geomIndex, int intIndex)Add an SegmentNode for intersection intIndex.voidaddIntersection(Coordinate intPt, int segmentIndex)Adds an intersection node for a given point and segment to this segment string.SegmentNodeaddIntersectionNode(Coordinate intPt, int segmentIndex)Adds an intersection node for a given point and segment to this segment string.voidaddIntersections(LineIntersector li, int segmentIndex, int geomIndex)Adds EdgeIntersections for one or both intersections found for a segment of an edge to the edge intersection list.CoordinategetCoordinate(int i)Gets the segment string coordinate at a given index.Coordinate[]getCoordinates()Gets the coordinates in this segment string.ObjectgetData()Gets the user-defined data for this segment string.Coordinate[]getNodedCoordinates()Gets a list of coordinates with all nodes included.static ListgetNodedSubstrings(Collection segStrings)Gets theSegmentStrings which result from splitting this string at node points.static voidgetNodedSubstrings(Collection segStrings, Collection resultEdgelist)Adds the nodedSegmentStrings which result from splitting this string at node points.SegmentNodeListgetNodeList()intgetSegmentOctant(int index)Gets the octant of the segment starting at vertexindex.booleanhasNodes()Tests whether any nodes have been added.booleanisClosed()Tests if a segment string is a closed ring.voidsetData(Object data)Sets the user-defined data for this segment string.intsize()Gets the number of coordinates in this segment string.StringtoString()-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.locationtech.jts.noding.SegmentString
nextInRing, prevInRing
-
-
-
-
Constructor Detail
-
NodedSegmentString
public NodedSegmentString(Coordinate[] pts, Object data)
Creates a instance from a list of vertices and optional data object.- Parameters:
pts- the vertices of the segment stringdata- the user-defined data of this segment string (may be null)
-
NodedSegmentString
public NodedSegmentString(SegmentString ss)
Creates a new instance from aSegmentString.- Parameters:
ss- the segment string to use
-
-
Method Detail
-
getNodedSubstrings
public static List getNodedSubstrings(Collection segStrings)
Gets theSegmentStrings which result from splitting this string at node points.- Parameters:
segStrings- a Collection of NodedSegmentStrings- Returns:
- a Collection of NodedSegmentStrings representing the substrings
-
getNodedSubstrings
public static void getNodedSubstrings(Collection segStrings, Collection resultEdgelist)
Adds the nodedSegmentStrings which result from splitting this string at node points.- Parameters:
segStrings- a Collection of NodedSegmentStringsresultEdgelist- a List which will collect the NodedSegmentStrings representing the substrings
-
getData
public Object getData()
Gets the user-defined data for this segment string.- Specified by:
getDatain interfaceSegmentString- Returns:
- the user-defined data
-
setData
public void setData(Object data)
Sets the user-defined data for this segment string.- Specified by:
setDatain interfaceSegmentString- Parameters:
data- an Object containing user-defined data
-
getNodeList
public SegmentNodeList getNodeList()
-
size
public int size()
Description copied from interface:SegmentStringGets the number of coordinates in this segment string.- Specified by:
sizein interfaceSegmentString- Returns:
- the number of coordinates
-
getCoordinate
public Coordinate getCoordinate(int i)
Description copied from interface:SegmentStringGets the segment string coordinate at a given index.- Specified by:
getCoordinatein interfaceSegmentString- Parameters:
i- the coordinate index- Returns:
- the coordinate at the index
-
getCoordinates
public Coordinate[] getCoordinates()
Description copied from interface:SegmentStringGets the coordinates in this segment string.- Specified by:
getCoordinatesin interfaceSegmentString- Returns:
- the coordinates as an array
-
getNodedCoordinates
public Coordinate[] getNodedCoordinates()
Gets a list of coordinates with all nodes included.- Returns:
- an array of coordinates include nodes
-
isClosed
public boolean isClosed()
Description copied from interface:SegmentStringTests if a segment string is a closed ring.- Specified by:
isClosedin interfaceSegmentString- Returns:
- true if the segment string is closed
-
hasNodes
public boolean hasNodes()
Tests whether any nodes have been added.- Returns:
- true if the segment string has nodes
-
getSegmentOctant
public int getSegmentOctant(int index)
Gets the octant of the segment starting at vertexindex.- Parameters:
index- the index of the vertex starting the segment. Must not be the last index in the vertex list- Returns:
- the octant of the segment at the vertex
-
addIntersections
public void addIntersections(LineIntersector li, int segmentIndex, int geomIndex)
Adds EdgeIntersections for one or both intersections found for a segment of an edge to the edge intersection list.
-
addIntersection
public void addIntersection(LineIntersector li, int segmentIndex, int geomIndex, int intIndex)
Add an SegmentNode for intersection intIndex. An intersection that falls exactly on a vertex of the SegmentString is normalized to use the higher of the two possible segmentIndexes
-
addIntersection
public void addIntersection(Coordinate intPt, int segmentIndex)
Adds an intersection node for a given point and segment to this segment string.- Specified by:
addIntersectionin interfaceNodableSegmentString- Parameters:
intPt- the location of the intersectionsegmentIndex- the index of the segment containing the intersection
-
addIntersectionNode
public SegmentNode addIntersectionNode(Coordinate intPt, int segmentIndex)
Adds an intersection node for a given point and segment to this segment string. If an intersection already exists for this exact location, the existing node will be returned.- Parameters:
intPt- the location of the intersectionsegmentIndex- the index of the segment containing the intersection- Returns:
- the intersection node for the point
-
-