|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object java.awt.geom.FlatteningPathIterator
The 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.
Field Summary | |
(package private) double |
curx
|
(package private) double |
cury
|
(package private) boolean |
done
|
(package private) static int |
GROW_SIZE
|
(package private) double[] |
hold
|
(package private) int |
holdEnd
|
(package private) int |
holdIndex
|
(package private) int |
holdType
|
(package private) int |
levelIndex
|
(package private) int[] |
levels
|
(package private) int |
limit
|
(package private) double |
movx
|
(package private) double |
movy
|
(package private) double |
squareflat
|
(package private) PathIterator |
src
|
Fields inherited from interface java.awt.geom.PathIterator |
SEG_CLOSE, SEG_CUBICTO, SEG_LINETO, SEG_MOVETO, SEG_QUADTO, WIND_EVEN_ODD, WIND_NON_ZERO |
Constructor Summary | |
FlatteningPathIterator(PathIterator src,
double flatness)
Constructs a new FlatteningPathIterator object that
flattens a path as it iterates over it. |
|
FlatteningPathIterator(PathIterator src,
double flatness,
int limit)
Constructs a new FlatteningPathIterator object
that flattens a path as it iterates over it.
|
Method Summary | |
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. |
(package private) void |
ensureHoldCapacity(int want)
|
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. |
private void |
next(boolean doNext)
|
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
static final int GROW_SIZE
PathIterator src
double squareflat
int limit
double[] hold
double curx
double cury
double movx
double movy
int holdType
int holdEnd
int holdIndex
int[] levels
int levelIndex
boolean done
Constructor Detail |
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 segment
IllegalArgumentException
- if
flatness
or limit
is less than zeroMethod Detail |
public double getFlatness()
FlatteningPathIterator
.public int getRecursionLimit()
FlatteningPathIterator
.public int getWindingRule()
getWindingRule
in interface PathIterator
PathIterator.WIND_EVEN_ODD
,
PathIterator.WIND_NON_ZERO
public boolean isDone()
isDone
in interface PathIterator
true
if all the segments have
been read; false
otherwise.void ensureHoldCapacity(int want)
public void next()
next
in interface PathIterator
private void next(boolean doNext)
public int currentSegment(float[] coords)
currentSegment
in interface PathIterator
coords
- an array that holds the data returned from
this method
NoSuchElementException
- if there
are no more elements in the flattening path to be
returned.PathIterator.SEG_MOVETO
,
PathIterator.SEG_LINETO
,
PathIterator.SEG_CLOSE
public int currentSegment(double[] coords)
currentSegment
in interface PathIterator
coords
- an array that holds the data returned from
this method
NoSuchElementException
- if there
are no more elements in the flattening path to be
returned.PathIterator.SEG_MOVETO
,
PathIterator.SEG_LINETO
,
PathIterator.SEG_CLOSE
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |