Package org.geotools.geometry.util
Class XRectangle2D
- Object
- 
- RectangularShape
- 
- Rectangle2D
- 
- XRectangle2D
 
 
 
- 
- All Implemented Interfaces:
- Shape,- Serializable,- Cloneable
 
 public class XRectangle2D extends Rectangle2D implements Serializable Serializable, high-performance double-precision rectangle. Instead of usingx,y,widthandheight, this class store rectangle's coordinates into the following fields:xmin,xmax,yminetymax. Methods likescontainsandintersectsare faster, which make this class more appropriate for using intensively inside a loop. Furthermore, this class work correctly with infinites and NaN values.- Since:
- 2.0
- Author:
- Martin Desruisseaux (IRD)
- See Also:
- Serialized Form
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from class Rectangle2DRectangle2D.Double, Rectangle2D.Float
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static Rectangle2DINFINITYAn immutable instance of aRectangle2Dwith bounds extending toward infinities.protected doublexmaxMaximal x coordinate.protected doublexminMinimal x coordinate.protected doubleymaxMaximal y coordinate.protected doubleyminMinimal y coordinate.- 
Fields inherited from class Rectangle2DOUT_BOTTOM, OUT_LEFT, OUT_RIGHT, OUT_TOP
 
- 
 - 
Constructor SummaryConstructors Constructor Description XRectangle2D()Construct a default rectangle.XRectangle2D(double x, double y, double width, double height)Construct a rectangle with the specified location and dimension.XRectangle2D(Rectangle2D rect)Construct a rectangle with the same coordinates than the supplied rectangle.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidadd(double x, double y)Adds a point, specified by the double precision argumentsxandy, to thisRectangle2D.voidadd(Rectangle2D rect)Adds aRectangle2Dobject to thisRectangle2D.booleancontains(double x, double y)Tests if a specified coordinate is inside the boundary of thisRectangle2D.booleancontains(double x, double y, double width, double height)Tests if the interior of thisRectangle2Dentirely contains the specified set of rectangular coordinates.booleancontains(Rectangle2D rect)Tests if the interior of this shape entirely contains the specified rectangle.static booleancontainsInclusive(Rectangle2D outter, Rectangle2D inner)Tests if the interior of theinnerrectangle is contained in the interior and/or the edge of theoutterrectangle.static XRectangle2DcreateFromExtremums(double xmin, double ymin, double xmax, double ymax)Create a rectangle using maximal x and y values rather than width and height.Rectangle2DcreateIntersection(Rectangle2D rect)Returns a newRectangle2Dobject representing the intersection of thisRectangle2Dwith the specifiedRectangle2D.Rectangle2DcreateUnion(Rectangle2D rect)Returns a newRectangle2Dobject representing the union of thisRectangle2Dwith the specifiedRectangle2D.static booleanequalsEpsilon(Rectangle2D rect1, Rectangle2D rect2)Returnstrueif the two rectangles are equals up to an epsilon value.doublegetCenterX()Returns the X coordinate of the center of the rectangle.doublegetCenterY()Returns the Y coordinate of the center of the rectangle.doublegetHeight()Returns the height of the framing rectangle indoubleprecision.doublegetMaxX()Returns the largest X coordinate of the rectangle.doublegetMaxY()Returns the largest Y coordinate of the rectangle.doublegetMinX()Returns the smallest X coordinate of the rectangle.doublegetMinY()Returns the smallest Y coordinate of the rectangle.doublegetWidth()Returns the width of the framing rectangle indoubleprecision.doublegetX()Returns the X coordinate of the upper left corner of the framing rectangle indoubleprecision.doublegetY()Returns the Y coordinate of the upper left corner of the framing rectangle indoubleprecision.static booleanintersectInclusive(Rectangle2D rect1, Rectangle2D rect2)Tests if the interior and/or the edge of two rectangles intersect.static booleanintersectInclusive(Shape shape, Rectangle2D rect)Tests if the interior of theShapeintersects the interior of a specified rectangle.booleanintersects(double x, double y, double width, double height)Tests if the interior of thisRectangle2Dintersects the interior of a specified set of rectangular coordinates.booleanintersects(Rectangle2D rect)Tests if the interior of this shape intersects the interior of a specified rectangle.booleanisEmpty()Determines whether theRectangularShapeis empty.intoutcode(double x, double y)Determines where the specified coordinates lie with respect to thisRectangle2D.voidsetRect(double x, double y, double width, double height)Sets the location and size of thisRectangle2Dto the specified double values.voidsetRect(Rectangle2D r)Sets thisRectangle2Dto be the same as the specifiedRectangle2D.StringtoString()Returns theStringrepresentation of thisRectangle2D.- 
Methods inherited from class Rectangle2Dadd, equals, getBounds2D, getPathIterator, getPathIterator, hashCode, intersect, intersectsLine, intersectsLine, outcode, setFrame, union
 - 
Methods inherited from class RectangularShapeclone, contains, getBounds, getFrame, setFrame, setFrame, setFrameFromCenter, setFrameFromCenter, setFrameFromDiagonal, setFrameFromDiagonal
 
- 
 
- 
- 
- 
Field Detail- 
INFINITYpublic static final Rectangle2D INFINITY An immutable instance of aRectangle2Dwith bounds extending toward infinities. ThegetMinX()andgetMinY()methods return alwaysDouble.NEGATIVE_INFINITY, while thegetMaxX()andgetMaxY()methods return alwaysDouble.POSITIVE_INFINITY. This rectangle can be used as argument in theXRectangle2Dconstructor for initializing a newXRectangle2Dto infinite bounds.
 - 
xminprotected double xmin Minimal x coordinate.
 - 
yminprotected double ymin Minimal y coordinate.
 - 
xmaxprotected double xmax Maximal x coordinate.
 - 
ymaxprotected double ymax Maximal y coordinate.
 
- 
 - 
Constructor Detail- 
XRectangle2Dpublic XRectangle2D() Construct a default rectangle. Initial coordinates are(0,0,0,0).
 - 
XRectangle2Dpublic XRectangle2D(double x, double y, double width, double height)Construct a rectangle with the specified location and dimension. This constructor uses the same signature thanRectangle2Dfor consistency.
 - 
XRectangle2Dpublic XRectangle2D(Rectangle2D rect) Construct a rectangle with the same coordinates than the supplied rectangle.- Parameters:
- rect- The rectangle, or- nullin none (in which case this constructor is equivalents to the no-argument constructor). Use- INFINITYfor initializing this- XRectangle2Dwith infinite bounds.
 
 
- 
 - 
Method Detail- 
createFromExtremumspublic static XRectangle2D createFromExtremums(double xmin, double ymin, double xmax, double ymax) Create a rectangle using maximal x and y values rather than width and height. This factory avoid the problem of NaN values when extremums are infinite numbers.
 - 
isEmptypublic boolean isEmpty() Determines whether theRectangularShapeis empty. When theRectangularShapeis empty, it encloses no area.- Specified by:
- isEmptyin class- RectangularShape
- Returns:
- trueif the- RectangularShapeis empty;- falseotherwise.
 
 - 
getXpublic double getX() Returns the X coordinate of the upper left corner of the framing rectangle indoubleprecision.- Specified by:
- getXin class- RectangularShape
- Returns:
- the x coordinate of the upper left corner of the framing rectangle.
 
 - 
getYpublic double getY() Returns the Y coordinate of the upper left corner of the framing rectangle indoubleprecision.- Specified by:
- getYin class- RectangularShape
- Returns:
- the y coordinate of the upper left corner of the framing rectangle.
 
 - 
getWidthpublic double getWidth() Returns the width of the framing rectangle indoubleprecision.- Specified by:
- getWidthin class- RectangularShape
- Returns:
- the width of the framing rectangle.
 
 - 
getHeightpublic double getHeight() Returns the height of the framing rectangle indoubleprecision.- Specified by:
- getHeightin class- RectangularShape
- Returns:
- the height of the framing rectangle.
 
 - 
getMinXpublic double getMinX() Returns the smallest X coordinate of the rectangle.- Overrides:
- getMinXin class- RectangularShape
 
 - 
getMinYpublic double getMinY() Returns the smallest Y coordinate of the rectangle.- Overrides:
- getMinYin class- RectangularShape
 
 - 
getMaxXpublic double getMaxX() Returns the largest X coordinate of the rectangle.- Overrides:
- getMaxXin class- RectangularShape
 
 - 
getMaxYpublic double getMaxY() Returns the largest Y coordinate of the rectangle.- Overrides:
- getMaxYin class- RectangularShape
 
 - 
getCenterXpublic double getCenterX() Returns the X coordinate of the center of the rectangle.- Overrides:
- getCenterXin class- RectangularShape
 
 - 
getCenterYpublic double getCenterY() Returns the Y coordinate of the center of the rectangle.- Overrides:
- getCenterYin class- RectangularShape
 
 - 
setRectpublic void setRect(double x, double y, double width, double height)Sets the location and size of thisRectangle2Dto the specified double values.- Specified by:
- setRectin class- Rectangle2D
- Parameters:
- x- the x coordinates to which to set the location of the upper left corner of this- Rectangle2D
- y- the y coordinates to which to set the location of the upper left corner of this- Rectangle2D
- width- the value to use to set the width of this- Rectangle2D
- height- the value to use to set the height of this- Rectangle2D
 
 - 
setRectpublic void setRect(Rectangle2D r) Sets thisRectangle2Dto be the same as the specifiedRectangle2D.- Overrides:
- setRectin class- Rectangle2D
- Parameters:
- r- the specified- Rectangle2D
 
 - 
intersectspublic boolean intersects(double x, double y, double width, double height)Tests if the interior of thisRectangle2Dintersects the interior of a specified set of rectangular coordinates.- Specified by:
- intersectsin interface- Shape
- Overrides:
- intersectsin class- Rectangle2D
- Parameters:
- x- the x coordinates of the upper left corner of the specified set of rectangular coordinates
- y- the y coordinates of the upper left corner of the specified set of rectangular coordinates
- width- the width of the specified set of rectangular coordinates
- height- the height of the specified set of rectangular coordinates
- Returns:
- trueif this- Rectangle2Dintersects the interior of a specified set of rectangular coordinates;- falseotherwise.
 
 - 
intersectspublic boolean intersects(Rectangle2D rect) Tests if the interior of this shape intersects the interior of a specified rectangle. This methods overrides the defaultRectangle2Dimplementation in order to work correctly with infinites and NaN values.- Specified by:
- intersectsin interface- Shape
- Overrides:
- intersectsin class- RectangularShape
- Parameters:
- rect- the specified rectangle.
- Returns:
- trueif this shape and the specified rectangle intersect each other.
- See Also:
- intersectInclusive(Rectangle2D, Rectangle2D)
 
 - 
intersectInclusivepublic static boolean intersectInclusive(Rectangle2D rect1, Rectangle2D rect2) Tests if the interior and/or the edge of two rectangles intersect. This method is similar tointersects(Rectangle2D)except for the following points:- This method doesn't test only if the interiors intersect. It tests for the edges as well.
- This method tests also rectangle with zero width or
       height (which are empty according
       Shapecontract). However, rectangle with negative width or height are still considered as empty.
- This method work correctly with infinites and NaN values.
 - Parameters:
- rect1- The first rectangle to test.
- rect2- The second rectangle to test.
- Returns:
- trueif the interior and/or the edge of the two specified rectangles intersects.
 
 - 
intersectInclusivepublic static boolean intersectInclusive(Shape shape, Rectangle2D rect) Tests if the interior of theShapeintersects the interior of a specified rectangle. This method might conservatively returntruewhen there is a high probability that the rectangle and the shape intersect, but the calculations to accurately determine this intersection are prohibitively expensive. This is similar toShape.intersects(Rectangle2D), except that this method tests also rectangle with zero width or height (which are empty accordingShapecontract). However, rectangle with negative width or height are still considered as empty.
 
 This method is said inclusive because it try to mimicintersectInclusive(Rectangle2D, Rectangle2D)behavior, at least for rectangle with zero width or height.- Parameters:
- shape- The shape.
- rect- The rectangle to test for inclusion.
- Returns:
- trueif the interior of the shape and the interior of the specified rectangle intersect, or are both highly likely to intersect.
 
 - 
equalsEpsilonpublic static boolean equalsEpsilon(Rectangle2D rect1, Rectangle2D rect2) Returnstrueif the two rectangles are equals up to an epsilon value.
 - 
containspublic boolean contains(double x, double y, double width, double height)Tests if the interior of thisRectangle2Dentirely contains the specified set of rectangular coordinates.- Specified by:
- containsin interface- Shape
- Overrides:
- containsin class- Rectangle2D
- Parameters:
- x- the x coordinates of the upper left corner of the specified set of rectangular coordinates
- y- the y coordinates of the upper left corner of the specified set of rectangular coordinates
- width- the width of the specified set of rectangular coordinates
- height- the height of the specified set of rectangular coordinates
- Returns:
- trueif this- Rectangle2Dentirely contains specified set of rectangular coordinates;- falseotherwise.
 
 - 
containspublic boolean contains(Rectangle2D rect) Tests if the interior of this shape entirely contains the specified rectangle. This methods overrides the defaultRectangle2Dimplementation in order to work correctly with infinites and NaN values.- Specified by:
- containsin interface- Shape
- Overrides:
- containsin class- RectangularShape
- Parameters:
- rect- the specified rectangle.
- Returns:
- trueif this shape entirely contains the specified rectangle.
 
 - 
containspublic boolean contains(double x, double y)Tests if a specified coordinate is inside the boundary of thisRectangle2D.- Specified by:
- containsin interface- Shape
- Overrides:
- containsin class- Rectangle2D
- Parameters:
- x- the x coordinates to test.
- y- the y coordinates to test.
- Returns:
- trueif the specified coordinates are inside the boundary of this- Rectangle2D;- falseotherwise.
 
 - 
containsInclusivepublic static boolean containsInclusive(Rectangle2D outter, Rectangle2D inner) Tests if the interior of theinnerrectangle is contained in the interior and/or the edge of theoutterrectangle. This method is similar tocontains(Rectangle2D)except for the following points: This method is said inclusive because it tests bounds as closed interval rather then open interval (the default Java2D behavior). Usage of closed interval is required if at least one rectangle may be the bounding box of a perfectly horizontal or vertical line; such a bounding box has 0 width or height.- Parameters:
- outter- The first rectangle to test.
- inner- The second rectangle to test.
- Returns:
- trueif the interior of- inneris inside the interior and/or the edge of- outter.
 
 - 
outcodepublic int outcode(double x, double y)Determines where the specified coordinates lie with respect to thisRectangle2D. This method computes a binary OR of the appropriate mask values indicating, for each side of thisRectangle2D, whether or not the specified coordinates are on the same side of the edge as the rest of thisRectangle2D.- Specified by:
- outcodein class- Rectangle2D
- Returns:
- the logical OR of all appropriate out codes.
- See Also:
- Rectangle2D.OUT_LEFT,- Rectangle2D.OUT_TOP,- Rectangle2D.OUT_RIGHT,- Rectangle2D.OUT_BOTTOM
 
 - 
createIntersectionpublic Rectangle2D createIntersection(Rectangle2D rect) Returns a newRectangle2Dobject representing the intersection of thisRectangle2Dwith the specifiedRectangle2D.- Specified by:
- createIntersectionin class- Rectangle2D
- Parameters:
- rect- the- Rectangle2Dto be intersected with this- Rectangle2D
- Returns:
- the largest Rectangle2Dcontained in both the specifiedRectangle2Dand in thisRectangle2D.
 
 - 
createUnionpublic Rectangle2D createUnion(Rectangle2D rect) Returns a newRectangle2Dobject representing the union of thisRectangle2Dwith the specifiedRectangle2D.- Specified by:
- createUnionin class- Rectangle2D
- Parameters:
- rect- the- Rectangle2Dto be combined with this- Rectangle2D
- Returns:
- the smallest Rectangle2Dcontaining both the specifiedRectangle2Dand thisRectangle2D.
 
 - 
addpublic void add(double x, double y)Adds a point, specified by the double precision argumentsxandy, to thisRectangle2D. The resultingRectangle2Dis the smallestRectangle2Dthat contains both the originalRectangle2Dand the specified point.After adding a point, a call to containswith the added point as an argument does not necessarily returntrue. Thecontainsmethod does not returntruefor points on the right or bottom edges of a rectangle. Therefore, if the added point falls on the left or bottom edge of the enlarged rectangle,containsreturnsfalsefor that point.- Overrides:
- addin class- Rectangle2D
 
 - 
addpublic void add(Rectangle2D rect) Adds aRectangle2Dobject to thisRectangle2D. The resultingRectangle2Dis the union of the twoRectangle2Dobjects.- Overrides:
- addin class- Rectangle2D
- Parameters:
- rect- the- Rectangle2Dto add to this- Rectangle2D.
 
 
- 
 
-