public class FlatteningPathIterator extends Object implements PathIterator
FlatteningPathIterator class returns a flattened view of
 another PathIterator object.  Other Shape
 classes can use this class to provide flattening behavior for their paths
 without having to perform the interpolation calculations themselves.SEG_CLOSE, SEG_CUBICTO, SEG_LINETO, SEG_MOVETO, SEG_QUADTO, WIND_EVEN_ODD, WIND_NON_ZERO| Constructor | Description | 
|---|---|
| FlatteningPathIterator(PathIterator src,
                      double flatness) | Constructs a new  FlatteningPathIteratorobject that
 flattens a path as it iterates over it. | 
| FlatteningPathIterator(PathIterator src,
                      double flatness,
                      int limit) | Constructs a new  FlatteningPathIteratorobject
 that flattens a path as it iterates over it. | 
| Modifier and Type | Method | Description | 
|---|---|---|
| int | currentSegment(double[] coords) | Returns the coordinates and type of the current path segment in
 the iteration. | 
| int | currentSegment(float[] coords) | Returns the coordinates and type of the current path segment in
 the iteration. | 
| double | getFlatness() | Returns the flatness of this iterator. | 
| int | getRecursionLimit() | Returns the recursion limit of this iterator. | 
| int | getWindingRule() | Returns the winding rule for determining the interior of the
 path. | 
| boolean | isDone() | Tests if the iteration is complete. | 
| void | next() | Moves the iterator to the next segment of the path forwards
 along the primary direction of traversal as long as there are
 more points in that direction. | 
public FlatteningPathIterator(PathIterator src, double flatness)
FlatteningPathIterator object that
 flattens a path as it iterates over it.  The iterator does not
 subdivide any curve read from the source iterator to more than
 10 levels of subdivision which yields a maximum of 1024 line
 segments per curve.src - the original unflattened path being iterated overflatness - the maximum allowable distance between the
 control points and the flattened curvepublic FlatteningPathIterator(PathIterator src, double flatness, int limit)
FlatteningPathIterator object
 that flattens a path as it iterates over it.
 The limit parameter allows you to control the
 maximum number of recursive subdivisions that the iterator
 can make before it assumes that the curve is flat enough
 without measuring against the flatness parameter.
 The flattened iteration therefore never generates more than
 a maximum of (2^limit) line segments per curve.src - the original unflattened path being iterated overflatness - the maximum allowable distance between the
 control points and the flattened curvelimit - the maximum number of recursive subdivisions
 allowed for any curved segmentIllegalArgumentException - if
          flatness or limit
          is less than zeropublic double getFlatness()
FlatteningPathIterator.public int getRecursionLimit()
FlatteningPathIterator.public int getWindingRule()
getWindingRule in interface PathIteratorPathIterator.WIND_EVEN_ODD, 
PathIterator.WIND_NON_ZEROpublic boolean isDone()
isDone in interface PathIteratortrue if all the segments have
 been read; false otherwise.public void next()
next in interface PathIteratorpublic int currentSegment(float[] coords)
currentSegment in interface PathIteratorcoords - an array that holds the data returned from
 this methodNoSuchElementException - if there
          are no more elements in the flattening path to be
          returned.PathIterator.SEG_MOVETO, 
PathIterator.SEG_LINETO, 
PathIterator.SEG_CLOSEpublic int currentSegment(double[] coords)
currentSegment in interface PathIteratorcoords - an array that holds the data returned from
 this methodNoSuchElementException - if there
          are no more elements in the flattening path to be
          returned.PathIterator.SEG_MOVETO, 
PathIterator.SEG_LINETO, 
PathIterator.SEG_CLOSE Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.