返回介绍

java.awt.geom 类 QuadCurve2D

发布于 2019-10-04 09:50:26 字数 26619 浏览 1024 评论 0 收藏 0

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

public abstract class QuadCurve2D
extends Object
 
implements Shape, Cloneable
 

QuadCurve2D 类定义 (x, y) 坐标空间内的二次参数曲线段。

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


嵌套类摘要
staticclassQuadCurve2D.Double

使用 double 坐标指定的二次参数曲线段。

staticclassQuadCurve2D.Float

使用 float 坐标指定的二次参数曲线段。

构造方法摘要
protectedQuadCurve2D()

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

方法摘要
Objectclone()

创建一个与此对象具有相同类和相同内容的新对象。

booleancontains(doublex, doubley)

测试指定点是否在此 QuadCurve2D 的形状的边界内。

booleancontains(doublex, doubley, doublew, doubleh)

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

booleancontains(Point2Dp)

测试指定 Point2D 是否在此 QuadCurve2D 的形状的边界内。

booleancontains(Rectangle2Dr)

测试此 QuadCurve2D 的形状的内部是否完全包含指定的 Rectangle2D

RectanglegetBounds()

返回此 QuadCurve2D 的边界框。

abstract Point2DgetCtrlPt()

返回控制点。

abstract doublegetCtrlX()

double 精度返回控制点的 X 坐标。

abstract doublegetCtrlY()

double 精度返回控制点的 Y 坐标。

doublegetFlatness()

返回此 QuadCurve2D 的平面度(或者说从控制点到连接端点的线的最大距离)。

staticdoublegetFlatness(double[]coords, intoffset)

返回由控制点(存储在指示数组中的指示索引处)指定的二次曲线的平面度(或者说从控制点到连接端点的线的最大距离)。

staticdoublegetFlatness(doublex1, doubley1, doublectrlx, doublectrly, doublex2, doubley2)

返回由指示控制点指定的二次曲线的平面度(或者说从控制点到连接端点的线的最大距离)。

doublegetFlatnessSq()

返回此 QuadCurve2D 的平面度(或者说从控制点到连接端点的线的最大距离)的平方。

staticdoublegetFlatnessSq(double[]coords, intoffset)

返回由控制点(存储在指示数组中的指示索引处)指定的二次曲线的平面度(或者说从控制点到连接端点的线的最大距离)的平方。

staticdoublegetFlatnessSq(doublex1, doubley1, doublectrlx, doublectrly, doublex2, doubley2)

返回由指示控制点指定的二次曲线的平面度(或者说从控制点到连接端点的线的最大距离)的平方。

abstract Point2DgetP1()

返回起始点。

abstract Point2DgetP2()

返回结束点。

PathIteratorgetPathIterator(AffineTransformat)

返回定义此 QuadCurve2D 的形状边界的迭代对象。

PathIteratorgetPathIterator(AffineTransformat, doubleflatness)

返回定义此 QuadCurve2D 的变平形状边界的迭代对象。

abstract doublegetX1()

double 精度返回起始点的 X 坐标。

abstract doublegetX2()

double 精度返回结束点的 X 坐标。

abstract doublegetY1()

double 精度返回起始点的 Y 坐标。

abstract doublegetY2()

double 精度返回结束点的 Y 坐标。

booleanintersects(doublex, doubley, doublew, doubleh)

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

booleanintersects(Rectangle2Dr)

测试 QuadCurve2D 的形状是否与指定 Rectangle2D 内部相交。

voidsetCurve(double[]coords, intoffset)

将此 QuadCurve2D 端点和控制点的位置设置为指定数组中指定偏移量的 double 坐标。

abstract voidsetCurve(doublex1, doubley1, doublectrlx, doublectrly, doublex2, doubley2)

将此曲线端点和控制点的位置设置为指定的 double 坐标。

voidsetCurve(Point2D[]pts, intoffset)

将此 QuadCurve2D 端点和控制点的位置设置为指定数组中指定偏移量的 Point2D 对象的坐标。

voidsetCurve(Point2Dp1, Point2Dcp, Point2Dp2)

将此 QuadCurve2D 端点和控制点的位置设置为指定的 Point2D 坐标。

voidsetCurve(QuadCurve2Dc)

将此 QuadCurve2D 端点和控制点的位置设置为与指定的 QuadCurve2D 相同。

staticintsolveQuadratic(double[]eqn)

解其系数位于 eqn 数组中的二次曲线,并将非复数的根放回该数组,同时返回根数。

staticintsolveQuadratic(double[]eqn, double[]res)

解其系数位于 eqn 数组中的二次曲线,并将非复数的根放入 res 数组,同时返回根数。

staticvoidsubdivide(double[]src, intsrcoff, double[]left, intleftoff, double[]right, intrightoff)

细分由存储在 src 数组 srcoff 到 ( srcoff + +5) 索引处的坐标指定的二次曲线,并将得到的两个细分曲线存储到所得数组的相应索引中。

voidsubdivide(QuadCurve2Dleft, QuadCurve2Dright)

细分此 QuadCurve2D 并将得到的两个细分曲线存储到 leftright 两个曲线参数中。

staticvoidsubdivide(QuadCurve2Dsrc, QuadCurve2Dleft, QuadCurve2Dright)

细分由 src 参数指定的二次曲线并将得到的两个细分曲线存储到 leftright 曲线参数中。

从类 java.lang.Object 继承的方法
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
从接口 java.awt.Shape 继承的方法
getBounds2D

构造方法详细信息

QuadCurve2D

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

方法详细信息

getX1

public abstract double getX1()
double 精度返回起始点的 X 坐标。
返回:
起始点的 X 坐标。

getY1

public abstract double getY1()
double 精度返回起始点的 Y 坐标。
返回:
起始点的 Y 坐标。

getP1

public abstract Point2D getP1()
返回起始点。
返回:
作为此 QuadCurve2D 起始点的 Point2D

getCtrlX

public abstract double getCtrlX()
double 精度返回控制点的 X 坐标。
返回:
控制点的 X 坐标。

getCtrlY

public abstract double getCtrlY()
double 精度返回控制点的 Y 坐标。
返回:
控制点的 Y 坐标。

getCtrlPt

public abstract Point2D getCtrlPt()
返回控制点。
返回:
作为此 Point2D 控制点的 Point2D

getX2

public abstract double getX2()
double 精度返回结束点的 X 坐标。
返回:
结束点的 X 坐标。

getY2

public abstract double getY2()
double 精度返回结束点的 Y 坐标。
返回:
结束点的 Y 坐标。

getP2

public abstract Point2D getP2()
返回结束点。
返回:
作为 Point2D 结束点的 Point 对象。

setCurve

public abstract void setCurve(doublex1,
                              doubley1,
                              doublectrlx,
                              doublectrly,
                              doublex2,
                              doubley2)
将此曲线端点和控制点的位置设置为指定的 double 坐标。
参数:
x1,y1 - 起始点的坐标
ctrlx,ctrly - 控制点的坐标
x2,y2 - 结束点的坐标

setCurve

public void setCurve(double[]coords,
                     intoffset)
将此 QuadCurve2D 端点和控制点的位置设置为指定数组中指定偏移量的 double 坐标。
参数:
coords - 包含坐标值的数组
offset - 用于开始从数组中获取坐标值并将其赋给此 QuadCurve2D 的索引

setCurve

public void setCurve(Point2Dp1,
                     Point2Dcp,
                     Point2Dp2)
将此 QuadCurve2D 端点和控制点的位置设置为指定的 Point2D 坐标。
参数:
p1 - 起始点
cp - 控制点
p2 - 结束点

setCurve

public void setCurve(Point2D[]pts,
                     intoffset)
将此 QuadCurve2D 端点和控制点的位置设置为指定数组中指定偏移量的 Point2D 对象的坐标。
参数:
pts - 包含定义坐标值的 Point2D 的数组
offset - pts 中的索引,从此处开始获取坐标值并将其赋给此 QuadCurve2D

setCurve

public void setCurve(QuadCurve2Dc)
将此 QuadCurve2D 端点和控制点的位置设置为与指定的 QuadCurve2D 相同。
参数:
c - 指定的 QuadCurve2D

getFlatnessSq

public static double getFlatnessSq(doublex1,
                                   doubley1,
                                   doublectrlx,
                                   doublectrly,
                                   doublex2,
                                   doubley2)
返回由指示控制点指定的二次曲线的平面度(或者说从控制点到连接端点的线的最大距离)的平方。
参数:
x1,y1 - 起始点的坐标
ctrlx,ctrly - 控制点的坐标
x2,y2 - 结束点的坐标
返回:
由指定坐标定义的二次曲线的平面度的平方

getFlatness

public static double getFlatness(doublex1,
                                 doubley1,
                                 doublectrlx,
                                 doublectrly,
                                 doublex2,
                                 doubley2)
返回由指示控制点指定的二次曲线的平面度(或者说从控制点到连接端点的线的最大距离)。
参数:
x1,y1 - 起始点的坐标
ctrlx,ctrly - 控制点的坐标
x2,y2 - 结束点的坐标
返回:
由指定坐标定义的二次曲线的平面度

getFlatnessSq

public static double getFlatnessSq(double[]coords,
                                   intoffset)
返回由控制点(存储在指示数组中的指示索引处)指定的二次曲线的平面度(或者说从控制点到连接端点的线的最大距离)的平方。
参数:
coords - 包含坐标值的数组
offset - coords 中的索引,从此处开始从数组获取值并将其赋予二次曲线
返回:
由指定数组中指定索引处的值定义的二次曲线的平面度。

getFlatness

public static double getFlatness(double[]coords,
                                 intoffset)
返回由控制点(存储在指示数组中的指示索引处)指定的二次曲线的平面度(或者说从控制点到连接端点的线的最大距离)。
参数:
coords - 包含坐标值的数组
offset - coords 中的索引,从此处开始从数组获取值并将其赋予二次曲线
返回:
由指定数组中指定偏移量定义的二次曲线的平面度。

getFlatnessSq

public double getFlatnessSq()
返回此 QuadCurve2D 的平面度(或者说从控制点到连接端点的线的最大距离)的平方。
返回:
QuadCurve2D 平面度的平方。

getFlatness

public double getFlatness()
返回此 QuadCurve2D 的平面度(或者说从控制点到连接端点的线的最大距离)。
返回:
QuadCurve2D 的平面度。

subdivide

public void subdivide(QuadCurve2Dleft,
                      QuadCurve2Dright)
细分此 QuadCurve2D 并将得到的两个细分曲线存储到 leftright 两个曲线参数中。 leftright 两个对象的任何一个或两者都可以与 QuadCurve2D 对象相同,也可以为 null
参数:
left - 用于存储左边一半或第一半细分曲线的 QuadCurve2D 对象
right - 用于存储右边一半或第二半细分曲线的 QuadCurve2D 对象

subdivide

public static void subdivide(QuadCurve2Dsrc,
                             QuadCurve2Dleft,
                             QuadCurve2Dright)
细分由 src 参数指定的二次曲线并将得到的两个细分曲线存储到 leftright 曲线参数中。 leftright 两个对象的任何一个或两者都可以与 src 对象相同,也可以为 null
参数:
src - 要细分的二次曲线
left - 用于存储左边一半或第一半细分曲线的 QuadCurve2D 对象
right - 用于存储右边一半或第二半细分曲线的 QuadCurve2D 对象

subdivide

public static void subdivide(double[]src,
                             intsrcoff,
                             double[]left,
                             intleftoff,
                             double[]right,
                             intrightoff)
细分由存储在 src 数组 srcoff 到 ( srcoff + +5) 索引处的坐标指定的二次曲线,并将得到的两个细分曲线存储到所得数组的相应索引中。 leftright 数组中的任何一个或两者都可以为 null ,也可以为到与 src 相同的数组和偏移量的引用。注意,第一个细分曲线的最后一点就是第二个细分曲线的第一点。因此,可以为 leftright 传递相同的数组,并且使用 rightoff 等于 ( leftoff + 6) 这样的偏移量,以避免为此公共点分配额外的存储区。
参数:
src - 保存源曲线坐标的数组
srcoff - 6 个源坐标的开头在数组中的偏移量
left - 存储第一半细分曲线坐标的数组
leftoff - 6 个左坐标的开头在数组中的偏移量
right - 存储第二半细分曲线坐标的数组
rightoff - 6 个右坐标的开头在数组中的偏移量

solveQuadratic

public static int solveQuadratic(double[]eqn)
解其系数位于 eqn 数组中的二次曲线,并将非复数的根放回该数组,同时返回根数。由以下方程表示二次曲线的解:
     eqn = {C, B, A};
     ax^2 + bx + c = 0

返回值 -1 用于区分常数方程(可以始终为 0 或永远不为 0)与不包含任何零的方程。

参数:
eqn - 包含二次曲线系数的数组
返回:
根数,如果方程是常数方程,则返回 -1

solveQuadratic

public static int solveQuadratic(double[]eqn,
                                 double[]res)
解其系数位于 eqn 数组中的二次曲线,并将非复数的根放入 res 数组,同时返回根数。由以下方程表示二次曲线的解:
     eqn = {C, B, A};
     ax^2 + bx + c = 0

返回值 -1 用于区分常数方程(可以始终为 0 或永远不为 0)与不包含任何零的方程。

参数:
eqn - 用于解二次曲线方程的系数的指定数组
res - 包含求解二次曲线方程所得非复数根的数组
返回:
根数,如果方程是常数方程,则返回 -1

contains

public boolean contains(doublex,
                        doubley)
测试指定点是否在此 QuadCurve2D 的形状的边界内。
指定者:
接口 Shape 中的 contains
参数:
x,y - 指定的坐标
返回:
如果指定的坐标在此 QuadCurve2D 的形状的边界内,则返回 true ;否则返回 false

contains

public boolean contains(Point2Dp)
测试指定 Point2D 是否在此 QuadCurve2D 的形状的边界内。
指定者:
接口 Shape 中的 contains
参数:
p - 指定的 Point2D
返回:
如果指定的 Point2D 在此 QuadCurve2D 的形状的边界内,则返回 true

intersects

public boolean intersects(doublex,
                          doubley,
                          doublew,
                          doubleh)
测试此 QuadCurve2D 的形状是否与指定的矩形坐标集的内部相交。
指定者:
接口 Shape 中的 intersects
参数:
x, y - 指定矩形区域左上角的坐标
w - 指定矩形区域的宽度
h - 指定矩形区域的高度
返回:
如果此 QuadCurve2D 的形状与指定矩形坐标集的内部相交,则返回 true ;否则返回 false
另请参见:
Area

intersects

public boolean intersects(Rectangle2Dr)
测试 QuadCurve2D 的形状是否与指定 Rectangle2D 内部相交。
指定者:
接口 Shape 中的 intersects
参数:
r - 指定的 Rectangle2D
返回:
如果此 QuadCurve2D 的形状与指定 Rectangle2D 的内部相交,则返回 true ;否则返回 false
另请参见:
Shape.intersects(double, double, double, double)

contains

public boolean contains(doublex,
                        doubley,
                        doublew,
                        doubleh)
测试此 QuadCurve2D 的形状的内部是否完全包含指定的矩形坐标集。
指定者:
接口 Shape 中的 contains
参数:
x, y - 指定矩形区域左上角的坐标
w - 指定矩形区域的宽度
h - 指定矩形区域的高度
返回:
如果此 QuadCurve2D 的形状的内部完全包含指定的矩形区域,则返回 true ;否则返回 false
另请参见:
Area , Shape.intersects(double, double, double, double)

contains

public boolean contains(Rectangle2Dr)
测试此 QuadCurve2D 的形状的内部是否完全包含指定的 Rectangle2D
指定者:
接口 Shape 中的 contains
参数:
r - 指定的 Rectangle2D
返回:
如果此 QuadCurve2D 的形状的内部完全包含指定的 Rectangle2D ,则返回 true ;否则返回 false
另请参见:
Shape.contains(double, double, double, double)

getBounds

public Rectangle getBounds()
返回此 QuadCurve2D 的边界框。
指定者:
接口 Shape 中的 getBounds
返回:
作为 QuadCurve2D 的形状边界框的 Rectangle
另请参见:
Shape.getBounds2D()

getPathIterator

public PathIterator getPathIterator(AffineTransformat)
返回定义此 QuadCurve2D 的形状边界的迭代对象。此类的迭代器不是多线程安全的,这意味着此 QuadCurve2D 类不保证对此 QuadCurve2D 对象几何形状所作的修改不会对该几何形状中正在进行的迭代产生影响。
指定者:
接口 Shape 中的 getPathIterator
参数:
at - 要应用于形状边界的可选的 AffineTransform
返回:
定义形状边界的 PathIterator 对象。

getPathIterator

public PathIterator getPathIterator(AffineTransformat,
                                    doubleflatness)
返回定义此 QuadCurve2D 的变平形状边界的迭代对象。此类的迭代器不是多线程安全的,这意味着此 QuadCurve2D 类不保证对此 QuadCurve2D 对象几何形状所作的修改不会对该几何形状中正在进行的迭代产生影响。
指定者:
接口 Shape 中的 getPathIterator
参数:
at - 要应用于形状边界的可选的 AffineTransform
flatness - 在由连接端点的直线取代曲线之前,细分曲线的控制端点相对于连接此曲线端点的线条的最大距离。
返回:
定义变平的形状边界的 PathIterator 对象。

clone

public Object clone()
创建一个与此对象具有相同类和相同内容的新对象。
覆盖:
Object 中的 clone
返回:
此实例的一个副本。
抛出:
OutOfMemoryError - 如果没有足够的内存。
从以下版本开始:
1.2
另请参见:
Cloneable

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

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

发布评论

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