public final class AffineTransforms2D extends Static
Matrix
and Java2D AffineTransform
instances.
Those AffineTransform
instances can be viewed as 3×3 matrices.Defined in the sisreferencing
module
Modifier and Type  Method and Description 

static AffineTransform 
castOrCopy(Matrix matrix)
Returns the given matrix as a Java2D affine transform.

static int 
getFlip(AffineTransform transform)
Returns
1 if one axis has been flipped, +1 if no axis has been flipped, or 0 if unknown. 
static double 
getRotation(AffineTransform transform)
Returns an estimation of the rotation angle in radians.

static double 
getScaleX0(AffineTransform transform)
Returns the magnitude of scale factor x by canceling the
effect of eventual flip and rotation.

static double 
getScaleY0(AffineTransform transform)
Returns the magnitude of scale factor y by canceling the
effect of eventual flip and rotation.

static int 
getSwapXY(AffineTransform transform)
Returns an estimation about whether the specified transform swaps x and y axes.

static Point2D 
inverseDeltaTransform(AffineTransform transform,
Point2D vector,
Point2D dest)
Calculates the inverse transform of a point without applying the translation components.

static Rectangle2D 
inverseTransform(AffineTransform transform,
Rectangle2D bounds,
Rectangle2D dest)
Calculates a rectangle which entirely contains the inverse transform of
bounds . 
static Matrix3 
toMatrix(AffineTransform transform)
Creates a 3×3 matrix from the given affine transform.

static Rectangle2D 
transform(AffineTransform transform,
Rectangle2D bounds,
Rectangle2D dest)
Calculates a rectangle which entirely contains the direct transform of
bounds . 
static Shape 
transform(AffineTransform transform,
Shape shape,
boolean allowOverwrite)
Transforms the given shape.

public static AffineTransform castOrCopy(Matrix matrix) throws IllegalArgumentException
AffineTransform
, then it is returned directly.
Otherwise the values are copied in a new AffineTransform
instance.matrix
 The matrix to returns as an affine transform, or null
.null
argument),
or a copy of the given matrix otherwise.IllegalArgumentException
 if the given matrix size is not 3×3 or if the matrix is not affine.Matrices.isAffine(Matrix)
public static Matrix3 toMatrix(AffineTransform transform)
transform
 The affine transform to copy as a matrix.public static Shape transform(AffineTransform transform, Shape shape, boolean allowOverwrite)
AffineTransform.createTransformedShape(Shape)
except that:
RectangularShape
and the given transform does not involve
rotation, then the returned shape may be some instance of the same class.overwrite
is true
.transform
 The affine transform to use.shape
 The shape to transform, or null
.allowOverwrite
 If true
, this method is allowed to overwrite shape
with the
transform result. If false
, then shape
is never modified.null
if the given shape was null.
May or may not be the same instance than the given shape.AffineTransform.createTransformedShape(Shape)
public static Rectangle2D transform(AffineTransform transform, Rectangle2D bounds, Rectangle2D dest)
bounds
.
This operation is equivalent to the following code, except that it can reuse the
given dest
rectangle and is potentially more efficient:
Note that if the given rectangle is an image bounds, then the given transform shall map the upperleft corner of pixels (as in Java2D usage), not the center of pixels (OGC usage).return transform.createTransformedShape(bounds).getBounds2D();
transform
 The affine transform to use.bounds
 The rectangle to transform, or null
.
This rectangle will not be modified except if dest
references the same object.dest
 Rectangle in which to place the result. If null
, a new rectangle will be created.bounds
rectangle, or null
if bounds
was null.org.apache.sis.geometry.Envelopes#transform(MathTransform2D, Rectangle2D, Rectangle2D)
public static Rectangle2D inverseTransform(AffineTransform transform, Rectangle2D bounds, Rectangle2D dest) throws NoninvertibleTransformException
bounds
.
This operation is equivalent to the following code, except that it can reuse the
given dest
rectangle and is potentially more efficient:
return createInverse().createTransformedShape(bounds).getBounds2D();
transform
 The affine transform to use.bounds
 The rectangle to transform, or null
.
This rectangle will not be modified except if dest
references the same object.dest
 Rectangle in which to place the result. If null
, a new rectangle will be created.bounds
rectangle, or null
if bounds
was null.NoninvertibleTransformException
 if the affine transform can't be inverted.public static Point2D inverseDeltaTransform(AffineTransform transform, Point2D vector, Point2D dest) throws NoninvertibleTransformException
transform
 The affine transform to use.vector
 The vector to transform stored as a point.
This point will not be modified except if dest
references the same object.dest
 Point in which to place the result. If null
, a new point will be created.vector
, or null
if source
was null.NoninvertibleTransformException
 if the affine transform can't be inverted.public static int getSwapXY(AffineTransform transform)
+1
if the (x, y) axis order seems to be
preserved, 1
if the transform seems to swap axis to the (y, x) axis order,
or 0
if this method can not make a decision.transform
 The affine transform to inspect.true
if the given transform seems to swap axis order.public static double getRotation(AffineTransform transform)
transform
 The affine transform to inspect.NaN
if the angle can not be estimated.public static int getFlip(AffineTransform transform)
1
if one axis has been flipped, +1
if no axis has been flipped, or 0 if unknown.
A flipped axis in an axis with direction reversed (typically the y axis). This method assumes
that the specified affine transform is built from arbitrary translations, scales or rotations, but no shear.
Note that it is not possible to determine which of the x or y axis has been flipped.
This method can be used in order to set the sign of a scale according the flipping state. The example below choose to apply the sign on the y scale, but this is an arbitrary (while common) choice:
This method is similar to the following code, except that this method distinguishes between "unflipped" and "unknown" states.double scaleX0 = getScaleX0(transform); double scaleY0 = getScaleY0(transform); int flip = getFlip(transform); if (flip != 0) { scaleY0 *= flip; // ... continue the process here. }
boolean flipped = (tr.getType() & TYPE_FLIP) != 0;
transform
 The affine transform to inspect.public static double getScaleX0(AffineTransform transform)
transform
 The affine transform to inspect.public static double getScaleY0(AffineTransform transform)
transform
 The affine transform to inspect.Copyright © 2010–2016 The Apache Software Foundation. All rights reserved.