返回介绍

java.awt.geom 类 Rectangle2D

发布于 2019-10-04 09:50:27 字数 22631 浏览 959 评论 0 收藏 0

java.lang.Object
  └java.awt.geom.RectangularShape
      └java.awt.geom.Rectangle2D
所有已实现的接口:
Shape, Cloneable
直接已知子类:
Rectangle, Rectangle2D.Double, Rectangle2D.Float

public abstract class Rectangle2D
extends RectangularShape
 

Rectangle2D 类描述通过位置 (x,y) 和尺寸 (wxh) 定义的矩形。

此类是所有存储 2D 矩形对象的惟一抽象超类。坐标的实际存储表示形式要靠子类来完成。


嵌套类摘要
staticclassRectangle2D.Double

Double 类定义以 double 坐标指定的矩形。

staticclassRectangle2D.Float

Float 类定义以 float 坐标指定的矩形。

字段摘要
staticintOUT_BOTTOM

指示点位于此 Rectangle2D 下方的位掩码。

staticintOUT_LEFT

指示点位于此 Rectangle2D 左边的位掩码。

staticintOUT_RIGHT

指示点位于此 Rectangle2D 右边的位掩码。

staticintOUT_TOP

指示点位于此 Rectangle2D 上方的位掩码。

构造方法摘要
protectedRectangle2D()

这是一个不可直接实例化的抽象类。

方法摘要
voidadd(doublenewx, doublenewy)

将由 double 精度参数 newxnewy 指定的点添加到此 Rectangle2D 中。

voidadd(Point2Dpt)

Point2D 对象 pt 添加到此 Rectangle2D 中。

voidadd(Rectangle2Dr)

Rectangle2D 对象添加到此 Rectangle2D 中。

booleancontains(doublex, doubley)

测试指定点是否在此 Rectangle2D 对象的边界内。

booleancontains(doublex, doubley, doublew, doubleh)

测试此 Rectangle2D 的内部是否完全包含指定矩形坐标集。

abstract Rectangle2DcreateIntersection(Rectangle2Dr)

返回一个新的 Rectangle2D 对象,它表示此 Rectangle2D 与指定 Rectangle2D 的交集。

abstract Rectangle2DcreateUnion(Rectangle2Dr)

返回一个新的 Rectangle2D 对象,它表示此 Rectangle2D 与指定 Rectangle2D 的并集。

booleanequals(Objectobj)

确定指定的 Object 是否与此 Rectangle2D 相等。

Rectangle2DgetBounds2D()

返回此 Rectangle2D 的高精度边界框。

PathIteratorgetPathIterator(AffineTransformat)

返回定义此 Rectangle2D 边界的迭代对象。

PathIteratorgetPathIterator(AffineTransformat, doubleflatness)

返回定义变平的 Rectangle2D 边界的迭代对象。

inthashCode()

返回此 Rectangle2D 的哈希码。

staticvoidintersect(Rectangle2Dsrc1, Rectangle2Dsrc2, Rectangle2Ddest)

将指定的一对源 Rectangle2D 对象相交,并将结果置于指定的目标 Rectangle2D 对象中。

booleanintersects(doublex, doubley, doublew, doubleh)

测试此 Rectangle2D 的内部是否与指定矩形坐标集的内部相交。

booleanintersectsLine(doublex1, doubley1, doublex2, doubley2)

测试指定线段是否与此 Rectangle2D 的内部相交。

booleanintersectsLine(Line2Dl)

测试指定的线段是否与此 Rectangle2D 的内部相交。

abstract intoutcode(doublex, doubley)

确定指定坐标相对于此 Rectangle2D 的位置。

intoutcode(Point2Dp)

确定指定的 Point2D 相对于此 Rectangle2D 的位置。

voidsetFrame(doublex, doubley, doublew, doubleh)

将此 Rectangle2D 外部边界的位置和大小设置为指定矩形值。

abstract voidsetRect(doublex, doubley, doublew, doubleh)

将此 Rectangle2D 的位置和大小设置为指定的 double 值。

voidsetRect(Rectangle2Dr)

将此 Rectangle2D 设置为与指定的 Rectangle2D 相同。

staticvoidunion(Rectangle2Dsrc1, Rectangle2Dsrc2, Rectangle2Ddest)

将一对源 Rectangle2D 对象相并,并将结果置于指定的目标 Rectangle2D 对象中。

从类 java.awt.geom.RectangularShape 继承的方法
clone, contains, contains, getBounds, getCenterX, getCenterY, getFrame, getHeight, getMaxX, getMaxY, getMinX, getMinY, getWidth, getX, getY, intersects, isEmpty, setFrame, setFrame, setFrameFromCenter, setFrameFromCenter, setFrameFromDiagonal, setFrameFromDiagonal
从类 java.lang.Object 继承的方法
finalize, getClass, notify, notifyAll, toString, wait, wait, wait

字段详细信息

OUT_LEFT

public static final int OUT_LEFT
指示点位于此 Rectangle2D 左边的位掩码。
从以下版本开始:
1.2
另请参见:
常量字段值

OUT_TOP

public static final int OUT_TOP
指示点位于此 Rectangle2D 上方的位掩码。
从以下版本开始:
1.2
另请参见:
常量字段值

OUT_RIGHT

public static final int OUT_RIGHT
指示点位于此 Rectangle2D 右边的位掩码。
从以下版本开始:
1.2
另请参见:
常量字段值

OUT_BOTTOM

public static final int OUT_BOTTOM
指示点位于此 Rectangle2D 下方的位掩码。
从以下版本开始:
1.2
另请参见:
常量字段值

构造方法详细信息

Rectangle2D

protected Rectangle2D()
这是一个不可直接实例化的抽象类。特定于类型的实现子类可用于实例化,并提供用于存储满足以下各种存取器方法所需信息的许多格式。
另请参见:
Rectangle2D.Float , Rectangle2D.Double , Rectangle

方法详细信息

setRect

public abstract void setRect(doublex,
                             doubley,
                             doublew,
                             doubleh)
将此 Rectangle2D 的位置和大小设置为指定的 double 值。
参数:
x,y - 用于设置此 Rectangle2D 左上角位置的坐标
w - 用于设置此 Rectangle2D 宽度的值
h - 用于设置此 Rectangle2D 高度的值
从以下版本开始:
1.2

setRect

public void setRect(Rectangle2Dr)
将此 Rectangle2D 设置为与指定的 Rectangle2D 相同。
参数:
r - 指定的 Rectangle2D
从以下版本开始:
1.2

intersectsLine

public boolean intersectsLine(doublex1,
                              doubley1,
                              doublex2,
                              doubley2)
测试指定线段是否与此 Rectangle2D 的内部相交。
参数:
x1,y1 - 指定线段的第一个端点
x2,y2 - 指定线段的第二个端点
返回:
如果指定线段与此 Rectangle2D 的内部相交,则返回 true ;否则返回 false
从以下版本开始:
1.2

intersectsLine

public boolean intersectsLine(Line2Dl)
测试指定的线段是否与此 Rectangle2D 的内部相交。
参数:
l - 要测试是否与此 Rectangle2D 内部相交的指定 Line2D
返回:
如果指定 Line2D 与此 Rectangle2D 的内部相交,则返回 true ;否则返回 false
从以下版本开始:
1.2

outcode

public abstract int outcode(doublex,
                            doubley)
确定指定坐标相对于此 Rectangle2D 的位置。此方法计算适当掩码值的二进制 OR,这些值针对此 Rectangle2D 的每个边指示指定坐标是否在此 Rectangle2D 的其余边缘的同一侧。
参数:
x,y - 指定的坐标
返回:
所有适当外码的逻辑或。
从以下版本开始:
1.2
另请参见:
OUT_LEFT , OUT_TOP , OUT_RIGHT , OUT_BOTTOM

outcode

public int outcode(Point2Dp)
确定指定的 Point2D 相对于此 Rectangle2D 的位置。此方法计算适当掩码值的二进制 OR,这些值针对此 Rectangle2D 的每个边指示指定的 Point2D 是否在此 Rectangle2D 的其余边缘的同一侧。
参数:
p - 指定的 Point2D
返回:
所有适当外码的逻辑或。
从以下版本开始:
1.2
另请参见:
OUT_LEFT , OUT_TOP , OUT_RIGHT , OUT_BOTTOM

setFrame

public void setFrame(doublex,
                     doubley,
                     doublew,
                     doubleh)
将此 Rectangle2D 外部边界的位置和大小设置为指定矩形值。
指定者:
RectangularShape 中的 setFrame
参数:
x, y - 用于设置此 Rectangle2D 外部边界左上角位置的坐标
w - 用于设置此 Rectangle2D 外部边界宽度的值
h - 用于设置此 Rectangle2D 外部边界高度的值
从以下版本开始:
1.2
另请参见:
RectangularShape.getFrame()

getBounds2D

public Rectangle2D getBounds2D()
返回此 Rectangle2D 的高精度边界框。
返回:
Rectangle2D 的边界框。
从以下版本开始:
1.2
另请参见:
Shape.getBounds()

contains

public boolean contains(doublex,
                        doubley)
测试指定点是否在此 Rectangle2D 对象的边界内。
参数:
x, y - 要测试的坐标
返回:
如果指定坐标在此 Rectangle2D 的边界内,则返回 true ;否则返回 false
从以下版本开始:
1.2

intersects

public boolean intersects(doublex,
                          doubley,
                          doublew,
                          doubleh)
测试此 Rectangle2D 的内部是否与指定矩形坐标集的内部相交。
参数:
x,y - 指定的矩形坐标集左上角的坐标
w - 指定的矩形坐标集的宽度
h - 指定的矩形坐标集的高度
返回:
如果此 Rectangle2D 与指定矩形坐标集的内部相交,则返回 true ;否则返回 false
从以下版本开始:
1.2
另请参见:
Area

contains

public boolean contains(doublex,
                        doubley,
                        doublew,
                        doubleh)
测试此 Rectangle2D 的内部是否完全包含指定矩形坐标集。
参数:
x, y - 指定的矩形坐标集左上角的坐标
w - 指定的矩形坐标集的宽度
h - 指定的矩形坐标集的高度
返回:
如果此 Rectangle2D 完全包含指定的矩形坐标集,则返回 true ;否则返回 false
从以下版本开始:
1.2
另请参见:
Area , Shape.intersects(double, double, double, double)

createIntersection

public abstract Rectangle2D createIntersection(Rectangle2Dr)
返回一个新的 Rectangle2D 对象,它表示此 Rectangle2D 与指定 Rectangle2D 的交集。
参数:
r - 与此 Rectangle2D 相交的 Rectangle2D
返回:
同时被指定的 Rectangle2D 和此 Rectangle2D 包含的最大的 Rectangle2D
从以下版本开始:
1.2

intersect

public static void intersect(Rectangle2Dsrc1,
                             Rectangle2Dsrc2,
                             Rectangle2Ddest)
将指定的一对源 Rectangle2D 对象相交,并将结果置于指定的目标 Rectangle2D 对象中。为了避免创建第三个 Rectangle2D 对象,将其中一个源矩形作为目标矩形也是可以的,但这样此方法将改写源矩形的初始点。
参数:
src1 - 要彼此相交的一对 Rectangle2D 对象中的第一个对象
src2 - 要彼此相交的一对 Rectangle2D 对象中的第二个对象
dest - 保存 src1src2 相交结果的 Rectangle2D
从以下版本开始:
1.2

createUnion

public abstract Rectangle2D createUnion(Rectangle2Dr)
返回一个新的 Rectangle2D 对象,它表示此 Rectangle2D 与指定 Rectangle2D 的并集。
参数:
r - 与此 Rectangle2D 合并的 Rectangle2D
返回:
包含指定 Rectangle2D 和此 Rectangle2D 的最小的 Rectangle2D
从以下版本开始:
1.2

union

public static void union(Rectangle2Dsrc1,
                         Rectangle2Dsrc2,
                         Rectangle2Ddest)
将一对源 Rectangle2D 对象相并,并将结果置于指定的目标 Rectangle2D 对象中。为了避免创建第三个 Rectangle2D 对象,将其中一个源矩形作为目标矩形也是可以的,但这样此方法将改写源矩形的初始点。
参数:
src1 - 要彼此相并的一对 Rectangle2D 对象中的第一个对象
src2 - 要彼此相并的 Rectangle2D 对象中的第二个对象
dest - 保存 src1src2 相并结果的 Rectangle2D
从以下版本开始:
1.2

add

public void add(doublenewx,
                doublenewy)
将由 double 精度参数 newxnewy 指定的点添加到此 Rectangle2D 中。所得到的 Rectangle2D 是同时包含原始 Rectangle2D 和指定点的最小的 Rectangle2D

在添加一个点后,以添加的点为参数调用 contains 方法不一定返回 true 。对于矩形的右边和底部边界线上的点, contains 方法不返回 true 。所以,如果添加的点落在放大的矩形的左边和底部边界线上,则 contains 将针对该点返回 false

参数:
newx,newy - 新点的坐标
从以下版本开始:
JDK1.0

add

public void add(Point2Dpt)
Point2D 对象 pt 添加到此 Rectangle2D 中。所得到的 Rectangle2D 是同时包含原始 Rectangle2D 和指定的 Point2D 的最小的 Rectangle2D

在添加一个点后,以添加的点为参数调用 contains 方法不一定返回 true 。对于矩形的右边和底部边界线上的点, contains 方法不返回 true 。所以,如果添加的点落在放大的矩形的左边和底部边界线上,则 contains 将针对该点返回 false

参数:
pt - 添加到此 Rectangle2D 中的新 Point2D
从以下版本开始:
JDK1.0

add

public void add(Rectangle2Dr)
Rectangle2D 对象添加到此 Rectangle2D 中。得到的 Rectangle2D 是两个 Rectangle2D 对象的并集。
参数:
r - 要添加到此 Rectangle2D 中的 Rectangle2D
从以下版本开始:
JDK1.0

getPathIterator

public PathIterator getPathIterator(AffineTransformat)
返回定义此 Rectangle2D 边界的迭代对象。此类的迭代器是多线程安全的,这意味着此 Rectangle2D 类保证对此 Rectangle2D 对象几何形状所作的修改不会对该几何形状中正在进行的迭代产生影响。
参数:
at - 一个可选的 AffineTransform ,用于在迭代中返回的坐标,如果需要未转换的坐标,则为 null
返回:
返回此 Rectangle2D 轮廓几何形状的 PathIterator 对象,一次一段。
从以下版本开始:
1.2

getPathIterator

public PathIterator getPathIterator(AffineTransformat,
                                    doubleflatness)
返回定义变平的 Rectangle2D 边界的迭代对象。因为矩形已经是平的,所以 flatness 参数会被忽略。此类的迭代器是多线程安全的,这意味着此 Rectangle2D 类保证对此 Rectangle2D 对象几何形状所作的修改不会对该几何形状中正在进行的迭代产生影响。
指定者:
接口 Shape 中的 getPathIterator
覆盖:
RectangularShape 中的 getPathIterator
参数:
at - 一个可选 AffineTransform ,用于在迭代中返回的坐标,如果需要未转换的坐标,则为 null
flatness - 用来近似曲线段的直线段偏离原始曲线上任一点的最大距离。因为矩形已经是平的,所以 flatness 参数会被忽略。
返回:
PathIterator 对象,该对象返回此 Rectangle2D 的轮廓的几何形状,一次一段。
从以下版本开始:
1.2

hashCode

public int hashCode()
返回此 Rectangle2D 的哈希码。
覆盖:
Object 中的 hashCode
返回:
Rectangle2D 对象的哈希码。
另请参见:
Object.equals(java.lang.Object) , Hashtable

equals

public boolean equals(Objectobj)
确定指定的 Object 是否与此 Rectangle2D 相等。如果指定的 ObjectRectangle2D 的实例并且位置和大小与此 Rectangle2D 相同,则其与此 Rectangle2D 相等。
覆盖:
Object 中的 equals
参数:
obj - 要与此 Rectangle2D 进行比较的 Object
返回:
如果 objRectangle2D 的实例并且与 Rectangle2D 具有相同值,则返回 true ;否则返回 false
从以下版本开始:
1.2
另请参见:
Object.hashCode() , Hashtable

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文