Package org.spongepowered.api.util
Class DiscreteTransform2
java.lang.Object
org.spongepowered.api.util.DiscreteTransform2
Represents a transform. It is 2 dimensional and discrete. It will never cause
 aliasing.
 
Rotations are performed around tile centers unless the tile corner flags are set to true. To prevent aliasing, quarter turn rotations are only legal on block centers or corners. Half turns can be performed additionally on line centers.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final DiscreteTransform2Represents an identity transformation.
- 
Method SummaryModifier and TypeMethodDescriptionandThen(DiscreteTransform2 that) Returns a transform that is the composition of the given transform with this transform.compose(DiscreteTransform2 that) Returns a transform that is the composition of this transform and the given transform.static DiscreteTransform2fromRotation(int quarterTurns) Returns a new transform representing a rotation in the xy plane around the origin.static DiscreteTransform2fromRotation(int quarterTurns, Vector2i point, boolean tileCorner) Returns a new transform representing a rotation in the xy plane, around a given point.static DiscreteTransform2fromRotation(int halfTurns, Vector2i point, boolean tileCornerX, boolean tileCornerY) Returns a new transform representing a rotation in the xy plane, around a given point.static DiscreteTransform2fromScale(int a) Returns a new transform representing a scaling.static DiscreteTransform2fromScale(int x, int y) Returns a new transform representing a scaling on each axis.static DiscreteTransform2Returns a new transform representing a scaling on each axis.static DiscreteTransform2fromTranslation(int x, int y) Returns a new transform representing a translation.static DiscreteTransform2fromTranslation(Vector2i vector) Returns a new transform representing a translation.invert()Inverts the transform and returns it as a new transform.matrix()Returns the matrix representation of the transform.static Optional<DiscreteTransform2> Returns a new transform from the given transformation matrix, if the resulting transform would be discrete.static DiscreteTransform2rotationAroundCenter(int quarterTurns, Vector2i size) Returns a new transform representing a centered rotation of an area of tiles.transform(int x, int y) Transform a vector represented as a pair of coordinates using this transform.Transforms a vector using this transforms.inttransformX(int x, int y) Transforms the x coordinate of a vector using this transform.inttransformX(Vector2i vector) Transforms the x coordinate of a vector using this transform.inttransformY(int x, int y) Transforms the y coordinate of a vector using this transform.inttransformY(Vector2i vector) Transforms the y coordinate of a vector using this transform.withRotation(int quarterTurns) Adds a rotation to this transform, in the xy plane, around the origin and returns it as a new transform.withRotation(int quarterTurns, Vector2i point, boolean tileCorner) Adds a a rotation to this transform, in the xy plane, around a given point, and returns it as a new transform.withRotation(int halfTurns, Vector2i point, boolean tileCornerX, boolean tileCornerY) Adds a a rotation to this transform, in the xy plane, around a given point, and returns it as a new transform.withScale(int a) Adds a scale factor to this transform and returns it as a new transform.withScale(int x, int y) Adds a scale factor for each axis to this transform and returns it as a new transform.Adds a scale factor for each axis to this transform and returns it as a new transform.withTransformation(DiscreteTransform2 transform) Adds another transformation to this transformation and returns int as a new transform.withTranslation(int x, int y) Adds a translation to this transform and returns it as a new transform.withTranslation(Vector2i vector) Adds a translation to this transform and returns it as a new transform.
- 
Field Details- 
IDENTITYRepresents an identity transformation. Does nothing!
 
- 
- 
Method Details- 
matrixReturns the matrix representation of the transform. It is 3D to allow it to include a translation.- Returns:
- The matrix for this transform
 
- 
transformTransforms a vector using this transforms.- Parameters:
- vector- The original vector
- Returns:
- The transformed vector
 
- 
transformTransform a vector represented as a pair of coordinates using this transform.- Parameters:
- x- The x coordinate of the original vector
- y- The y coordinate of the original vector
- Returns:
- The transformed vector
 
- 
transformXTransforms the x coordinate of a vector using this transform. Only creates a new object on the first call.- Parameters:
- vector- The original vector
- Returns:
- The transformed x coordinate
 
- 
transformXpublic int transformX(int x, int y) Transforms the x coordinate of a vector using this transform. Only creates a new object on the first call.- Parameters:
- x- The x coordinate of the original vector
- y- The y coordinate of the original vector
- Returns:
- The transformed x coordinate
 
- 
transformYTransforms the y coordinate of a vector using this transform. Only creates a new object on the first call.- Parameters:
- vector- The original vector
- Returns:
- The transformed y coordinate
 
- 
transformYpublic int transformY(int x, int y) Transforms the y coordinate of a vector using this transform. Only creates a new object on the first call.- Parameters:
- x- The x coordinate of the original vector
- y- The y coordinate of the original vector
- Returns:
- The transformed y coordinate
 
- 
invertInverts the transform and returns it as a new transform.- Returns:
- The inverse of this transform
 
- 
composeReturns a transform that is the composition of this transform and the given transform. The result will apply this transformation after the given one.- Parameters:
- that- The transform to compose with
- Returns:
- The new composed transform
 
- 
andThenReturns a transform that is the composition of the given transform with this transform. The result will apply the given transformation after this one.- Parameters:
- that- The transform to compose with
- Returns:
- The new composed transform
 
- 
withTranslationAdds a translation to this transform and returns it as a new transform.- Parameters:
- vector- The translation vector
- Returns:
- The translated transform as a copy
 
- 
withTranslationAdds a translation to this transform and returns it as a new transform.- Parameters:
- x- The x coordinate of the translation
- y- The y coordinate of the translation
- Returns:
- The translated transform as a copy
 
- 
withScaleAdds a scale factor to this transform and returns it as a new transform. This factor must be non-zero.- Parameters:
- a- The scale factor
- Returns:
- The scaled transform as a copy
 
- 
withScaleAdds a scale factor for each axis to this transform and returns it as a new transform. The factors must be non-zero.- Parameters:
- vector- The scale vector
- Returns:
- The scaled transform as a copy
 
- 
withScaleAdds a scale factor for each axis to this transform and returns it as a new transform. The factors must be non-zero.- Parameters:
- x- The scale factor on x
- y- The scale factor on y
- Returns:
- The scaled transform as a copy
 
- 
withRotationAdds a rotation to this transform, in the xy plane, around the origin and returns it as a new transform. The rotation is given is quarter turns. The actual rotation isquarterTurns * 90. The rotation is around the block center, not the corner.- Parameters:
- quarterTurns- The number of quarter turns in this rotation
- Returns:
- The rotated transform as a copy
 
- 
withRotationAdds a a rotation to this transform, in the xy plane, around a given point, and returns it as a new transform. The rotation is given is quarter turns. The actual rotation isquarterTurns * 90. The tile corner flag changes the point to be the tile upper corner instead of the center.- Parameters:
- quarterTurns- The number of quarter turns in this rotation
- point- The point of rotation, as tile coordinates
- tileCorner- Whether or not to use the corner of the tile instead of the center
- Returns:
- The rotated transform as a copy
 
- 
withRotationpublic DiscreteTransform2 withRotation(int halfTurns, Vector2i point, boolean tileCornerX, boolean tileCornerY) Adds a a rotation to this transform, in the xy plane, around a given point, and returns it as a new transform. The rotation is given is half turns. The actual rotation ishalfTurns * 180. The tile corner flags change the point to be the tile corner or edge instead of the center. When both flags are false, the center is used. When only one is true the edge on the opposite axis to the flag is used. When both are true the upper corner is used.- Parameters:
- halfTurns- The number of half turns in this rotation
- point- The point of rotation, as tile coordinates
- tileCornerX- Whether or not to use the corner of the tile instead of the center on the x axis
- tileCornerY- Whether or not to use the corner of the tile instead of the center on the y axis
- Returns:
- The rotated transform as a copy
 
- 
withTransformationAdds another transformation to this transformation and returns int as a new transform.- Parameters:
- transform- The transformation to add
- Returns:
- The added transforms as a copy
 
- 
ofReturns a new transform from the given transformation matrix, if the resulting transform would be discrete.- Parameters:
- matrix- The matrix to use for the transform
- Returns:
- The new transform, or Optional.empty()
 
- 
fromTranslationReturns a new transform representing a translation.- Parameters:
- vector- The translation vector
- Returns:
- The new translation transform
 
- 
fromTranslationReturns a new transform representing a translation.- Parameters:
- x- The x coordinate of the translation
- y- The y coordinate of the translation
- Returns:
- The new translation transform
 
- 
fromScaleReturns a new transform representing a scaling. The scale factor must be non-zero.- Parameters:
- a- The scale factor
- Returns:
- The new scale transform
 
- 
fromScaleReturns a new transform representing a scaling on each axis. The scale factors must be non-zero.- Parameters:
- vector- The scale vector
- Returns:
- The new scale transform
 
- 
fromScaleReturns a new transform representing a scaling on each axis. The scale factors must be non-zero.- Parameters:
- x- The scale factor on x
- y- The scale factor on y
- Returns:
- The new scale transform
 
- 
fromRotationReturns a new transform representing a rotation in the xy plane around the origin. The rotation is given is quarter turns. The actual rotation isquarterTurns * 90. The rotation is around the block center, not the corner.- Parameters:
- quarterTurns- The number of quarter turns in this rotation
- Returns:
- The new rotation transform
 
- 
fromRotationReturns a new transform representing a rotation in the xy plane, around a given point. The rotation is given is quarter turns. The actual rotation isquarterTurns * 90. The tile corner flag change the point to be the tile corner instead of the center.- Parameters:
- quarterTurns- The number of quarter turns in this rotation
- point- The point of rotation, as tile coordinates
- tileCorner- Whether or not to use the corner of the tile instead of the center
- Returns:
- The new rotation transform
 
- 
fromRotationpublic static DiscreteTransform2 fromRotation(int halfTurns, Vector2i point, boolean tileCornerX, boolean tileCornerY) Returns a new transform representing a rotation in the xy plane, around a given point. The rotation is given is half turns. The actual rotation ishalfTurns * 180. The tile corner flags change the point to be the tile corner or edge instead of the center. When both flags are false, the center is used. When only one is true the edge on the opposite axis to the flag is used. When both are true the upper corner is used.- Parameters:
- halfTurns- The number of half turns in this rotation
- point- The point of rotation, as tile coordinates
- tileCornerX- Whether or not to use the corner of the tile instead of the center on the x axis
- tileCornerY- Whether or not to use the corner of the tile instead of the center on the y axis
- Returns:
- The new rotation transform
 
- 
rotationAroundCenterReturns a new transform representing a centered rotation of an area of tiles. The rotation is given is quarter turns. The actual rotation isquarterTurns * 90. Areas with differing parities on the axes can only be rotated by multiples of 180 degrees.- Parameters:
- quarterTurns- The amount of quarter turns in this rotation
- size- The size of the area to rotate
- Returns:
- The new rotation transform
 
 
-