|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
java.lang.Object java.awt.geom.Line2D
public abstract class Line2D
Line2D
クラスは、(x,y)
座標空間のラインセグメントを表します。このクラスは、すべての Java 2D API と同じように、「ユーザー空間」というデフォルトの座標体系を使用します。 この座標体系では、y 軸の値は下方へ行くに従い増加し、x 軸の値は右へ行くに従い増加します。ユーザー空間座標系についての詳細は、「Java 2D Programmer's Guide」の「Coordinate Systems」のセクションを参照してください。
このクラスは、2D ラインセグメントを格納するすべてのオブジェクトの抽象スーパークラスにすぎません。座標の実際の記憶域表現はサブクラスに委ねられます。
入れ子のクラスの概要 | |
---|---|
static class |
Line2D.Double
double 座標で指定されたラインセグメントです。 |
static class |
Line2D.Float
float 座標で指定されたラインセグメントです。 |
コンストラクタの概要 | |
---|---|
protected |
Line2D()
これは、インスタンスを直接には生成できない abstract クラスです。 |
メソッドの概要 | |
---|---|
Object |
clone()
このオブジェクトと同じクラスの新しいオブジェクトを作成します。 |
boolean |
contains(double x,
double y)
指定された座標が、この Line2D の境界内にあるかどうかを判定します。 |
boolean |
contains(double x,
double y,
double w,
double h)
この Line2D の内部が、指定された矩形座標セットを完全に内包するかどうかを判定します。 |
boolean |
contains(Point2D p)
指定された Point2D が、この Line2D の境界内にあるかどうかを判定します。 |
boolean |
contains(Rectangle2D r)
この Line2D の内部が、指定された Rectangle2D を完全に内包するかどうかを判定します。 |
Rectangle |
getBounds()
Shape を完全に囲む整数型の Rectangle を返します。 |
abstract Point2D |
getP1()
この Line2D の始点を表す Point2D を返します。 |
abstract Point2D |
getP2()
この Line2D の終点を表す Point2D を返します。 |
PathIterator |
getPathIterator(AffineTransform at)
この Line2D の境界を定義する繰り返しオブジェクトを返します。 |
PathIterator |
getPathIterator(AffineTransform at,
double flatness)
平坦化された Line2D の境界を定義する繰り返しオブジェクトを返します。 |
abstract double |
getX1()
始点の X 座標を倍精度で返します。 |
abstract double |
getX2()
終点の X 座標を倍精度で返します。 |
abstract double |
getY1()
始点の Y 座標を倍精度で返します。 |
abstract double |
getY2()
終点の Y 座標を倍精度で返します。 |
boolean |
intersects(double x,
double y,
double w,
double h)
Shape の内部領域が、指定された矩形領域の内部領域と交差するかどうかを判定します。 |
boolean |
intersects(Rectangle2D r)
Shape の内部が、指定された Rectangle2D の内部と交差するかどうかを判定します。 |
boolean |
intersectsLine(double x1,
double y1,
double x2,
double y2)
(x1,y1) から (x2,y2) までのラインセグメントがこのラインセグメントと交差するかどうかを判定します。 |
boolean |
intersectsLine(Line2D l)
指定されたラインセグメントがこのラインセグメントと交差するかどうかを判定します。 |
static boolean |
linesIntersect(double x1,
double y1,
double x2,
double y2,
double x3,
double y3,
double x4,
double y4)
(x1,y1) から (x2,y2) までのラインセグメントが (x3,y3) から (x4,y4) までのラインセグメントと交差するかどうかを判定します。 |
double |
ptLineDist(double px,
double py)
点からこのラインまでの距離を返します。 |
static double |
ptLineDist(double x1,
double y1,
double x2,
double y2,
double px,
double py)
点からラインまでの距離を返します。 |
double |
ptLineDist(Point2D pt)
Point2D からこのラインまでの距離を返します。 |
double |
ptLineDistSq(double px,
double py)
点からこのラインまでの距離の 2 乗を返します。 |
static double |
ptLineDistSq(double x1,
double y1,
double x2,
double y2,
double px,
double py)
点からラインまでの距離の 2 乗を返します。 |
double |
ptLineDistSq(Point2D pt)
指定された Point2D からこのラインまでの距離の 2 乗を返します。 |
double |
ptSegDist(double px,
double py)
点からこのラインセグメントまでの距離を返します。 |
static double |
ptSegDist(double x1,
double y1,
double x2,
double y2,
double px,
double py)
点からラインセグメントまでの距離を返します。 |
double |
ptSegDist(Point2D pt)
Point2D からこのラインセグメントまでの距離を返します。 |
double |
ptSegDistSq(double px,
double py)
点からこのラインセグメントまでの距離の 2 乗を返します。 |
static double |
ptSegDistSq(double x1,
double y1,
double x2,
double y2,
double px,
double py)
点からラインセグメントまでの距離の 2 乗を返します。 |
double |
ptSegDistSq(Point2D pt)
Point2D からこのラインセグメントまでの距離の 2 乗を返します。 |
int |
relativeCCW(double px,
double py)
このラインセグメントを基準として、指定された点 (px,py) の位置を示すインジケータを返します。 |
static int |
relativeCCW(double x1,
double y1,
double x2,
double y2,
double px,
double py)
(x1,y1) から (x2,y2) までのラインセグメントに対する指定された点 (px,py) の位置を示すインジケータを返します。 |
int |
relativeCCW(Point2D p)
このラインセグメントを基準として、指定された Point2D の位置を示すインジケータを返します。 |
abstract void |
setLine(double x1,
double y1,
double x2,
double y2)
この Line2D の両方の終点の位置を、指定された double 座標に設定します。 |
void |
setLine(Line2D l)
この Line2D の両方の終点の位置を、指定された Line2D の終点と同じ位置に設定します。 |
void |
setLine(Point2D p1,
Point2D p2)
この Line2D の両方の終点の位置を、指定された Point2D 座標に設定します。 |
クラス java.lang.Object から継承されたメソッド |
---|
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
インタフェース java.awt.Shape から継承されたメソッド |
---|
getBounds2D |
コンストラクタの詳細 |
---|
protected Line2D()
Line2D.Float
,
Line2D.Double
メソッドの詳細 |
---|
public abstract double getX1()
Line2D
オブジェクトの始点の X 座標public abstract double getY1()
Line2D
オブジェクトの始点の Y 座標public abstract Point2D getP1()
Line2D
の始点を表す Point2D
を返します。
Line2D
の始点を表す Point2D
public abstract double getX2()
Line2D
オブジェクトの終点の X 座標public abstract double getY2()
Line2D
オブジェクトの終点の Y 座標public abstract Point2D getP2()
Line2D
の終点を表す Point2D
を返します。
Line2D
の終点を表す Point2D
public abstract void setLine(double x1, double y1, double x2, double y2)
Line2D
の両方の終点の位置を、指定された double 座標に設定します。
x1
- 始点の X 座標y1
- 始点の Y 座標x2
- 終点の X 座標y2
- 終点の Y 座標public void setLine(Point2D p1, Point2D p2)
Line2D
の両方の終点の位置を、指定された Point2D
座標に設定します。
p1
- このラインセグメントの始点を表す Point2D
p2
- このラインセグメントの終点を表す Point2D
public void setLine(Line2D l)
Line2D
の両方の終点の位置を、指定された Line2D
の終点と同じ位置に設定します。
l
- 指定された Line2D
public static int relativeCCW(double x1, double y1, double x2, double y2, double px, double py)
(x1,y1)
から (x2,y2)
までのラインセグメントに対する指定された点 (px,py)
の位置を示すインジケータを返します。戻り値は 1、-1、0 のいずれかで、指定された線が最初の終点 (x1,y1)
を基準にしてどの方向に回転すれば指定された点 (px,py)
をポイントするかを示します。 戻り値が 1 の場合、正の X 軸を負の Y 軸に向けて移動する方向にラインセグメントを回転することを示します。Java 2D で使用されるデフォルトの座標体系では、これは反時計方向になります。
戻り値が -1 の場合、正の X 軸を正の Y 軸に向けて移動する方向にラインセグメントを回転することを示します。Java 2D で使用されるデフォルトの座標体系では、これは時計方向になります。
戻り値が 0 の場合、点が正確にラインセグメント上にあることを示します。インジケータ値が 0 になることはまれであり、浮動小数点の丸めの問題により共線性の判断には利用できません。
点がラインセグメントの終点の間ではなく延長上にある場合、点が (x1,y1)
の外側のときは -1、(x2,y2)
の外側のときは 1 になります。
x1
- 指定されたラインセグメントの始点の X 座標y1
- 指定されたラインセグメントの終点の X 座標x2
- 指定されたラインセグメントの終点の X 座標y2
- 指定されたラインセグメントの終点の Y 座標px
- 指定されたラインセグメントと比較される、指定された点の X 座標py
- 指定されたラインセグメントと比較される、指定された点の Y 座標
public int relativeCCW(double px, double py)
(px,py)
の位置を示すインジケータを返します。戻り値の解釈については、relativeCCW(double, double, double, double, double, double)
のメソッドのコメントを参照してください。
px
- この Line2D
と比較される、指定された点の X 座標py
- この Line2D
と比較される、指定された点の Y 座標
Line2D
を基準にした指定された座標の位置を示す整数値relativeCCW(double, double, double, double, double, double)
public int relativeCCW(Point2D p)
Point2D
の位置を示すインジケータを返します。戻り値の解釈については、relativeCCW(double, double, double, double, double, double)
のメソッドのコメントを参照してください。
p
- この Line2D
と比較される、指定された Point2D
Line2D
を基準にした指定された Point2D
の位置を示す整数値relativeCCW(double, double, double, double, double, double)
public static boolean linesIntersect(double x1, double y1, double x2, double y2, double x3, double y3, double x4, double y4)
(x1,y1)
から (x2,y2)
までのラインセグメントが (x3,y3)
から (x4,y4)
までのラインセグメントと交差するかどうかを判定します。
x1
- 最初に指定されたラインセグメントの始点の X 座標y1
- 最初に指定されたラインセグメントの始点の Y 座標x2
- 最初に指定されたラインセグメントの終点の X 座標y2
- 最初に指定されたラインセグメントの終点の Y 座標x3
- 2 番目に指定されたラインセグメントの始点の X 座標y3
- 2 番目に指定されたラインセグメントの始点の Y 座標x4
- 2 番目に指定されたラインセグメントの終点の X 座標y4
- 2 番目に指定されたラインセグメントの終点の Y 座標
true
、そうでない場合は false
public boolean intersectsLine(double x1, double y1, double x2, double y2)
(x1,y1)
から (x2,y2)
までのラインセグメントがこのラインセグメントと交差するかどうかを判定します。
x1
- 指定されたラインセグメントの始点の X 座標y1
- 指定されたラインセグメントの終点の X 座標x2
- 指定されたラインセグメントの終点の X 座標y2
- 指定されたラインセグメントの終点の Y 座標
true
、そうでない場合は false
public boolean intersectsLine(Line2D l)
l
- 指定された Line2D
true
、そうでない場合は false
public static double ptSegDistSq(double x1, double y1, double x2, double y2, double px, double py)
x1
- 指定されたラインセグメントの始点の X 座標y1
- 指定されたラインセグメントの終点の X 座標x2
- 指定されたラインセグメントの終点の X 座標y2
- 指定されたラインセグメントの終点の Y 座標px
- 指定されたラインセグメントに対して測定される、指定された点の X 座標py
- 指定されたラインセグメントに対して測定される、指定された点の Y 座標
ptLineDistSq(double, double, double, double, double, double)
public static double ptSegDist(double x1, double y1, double x2, double y2, double px, double py)
x1
- 指定されたラインセグメントの始点の X 座標y1
- 指定されたラインセグメントの終点の X 座標x2
- 指定されたラインセグメントの終点の X 座標y2
- 指定されたラインセグメントの終点の Y 座標px
- 指定されたラインセグメントに対して測定される、指定された点の X 座標py
- 指定されたラインセグメントに対して測定される、指定された点の Y 座標
ptLineDist(double, double, double, double, double, double)
public double ptSegDistSq(double px, double py)
px
- このラインセグメントに対して測定される、指定された点の X 座標py
- このラインセグメントに対して測定される、指定された点の Y 座標
ptLineDistSq(double, double)
public double ptSegDistSq(Point2D pt)
Point2D
からこのラインセグメントまでの距離の 2 乗を返します。この距離は、指定された点と、現在の線の終点の間でもっとも近い点の間の距離です。指定された点が終点の間のラインセグメントと交差する場合、このメソッドは 0.0 を返します。
pt
- このラインセグメントに対して測定される、指定された Point2D
Point2D
から現在のラインセグメントまでの距離の 2 乗を表す double 値ptLineDistSq(Point2D)
public double ptSegDist(double px, double py)
px
- このラインセグメントに対して測定される、指定された点の X 座標py
- このラインセグメントに対して測定される、指定された点の Y 座標
ptLineDist(double, double)
public double ptSegDist(Point2D pt)
Point2D
からこのラインセグメントまでの距離を返します。この距離は、指定された点と、現在の線の終点の間でもっとも近い点の間の距離です。指定された点が終点の間のラインセグメントと交差する場合、このメソッドは 0.0 を返します。
pt
- このラインセグメントに対して測定される、指定された Point2D
Point2D
から現在のラインセグメントまでの距離を表す double 値ptLineDist(Point2D)
public static double ptLineDistSq(double x1, double y1, double x2, double y2, double px, double py)
x1
- 指定されたラインの始点の X 座標y1
- 指定されたラインの始点の Y 座標x2
- 指定されたラインの終点の X 座標y2
- 指定されたラインの終点の Y 座標px
- 指定されたラインに対して測定される、指定された点の X 座標py
- 指定されたラインに対して測定される、指定された点の Y 座標
ptSegDistSq(double, double, double, double, double, double)
public static double ptLineDist(double x1, double y1, double x2, double y2, double px, double py)
x1
- 指定されたラインの始点の X 座標y1
- 指定されたラインの始点の Y 座標x2
- 指定されたラインの終点の X 座標y2
- 指定されたラインの終点の Y 座標px
- 指定されたラインに対して測定される、指定された点の X 座標py
- 指定されたラインに対して測定される、指定された点の Y 座標
ptSegDist(double, double, double, double, double, double)
public double ptLineDistSq(double px, double py)
Line2D
によって定義される無限に延長された線上のもっとも近い点の間の距離です。指定された点が線と交差する場合、このメソッドは 0.0 を返します。
px
- このラインに対して測定される、指定された点の X 座標py
- このラインに対して測定される、指定された点の Y 座標
ptSegDistSq(double, double)
public double ptLineDistSq(Point2D pt)
Point2D
からこのラインまでの距離の 2 乗を返します。この距離は、指定された点と、この Line2D
によって定義される無限に延長された線上のもっとも近い点の間の距離です。指定された点が線と交差する場合、このメソッドは 0.0 を返します。
pt
- このラインに対して測定される、指定された Point2D
Point2D
から現在のラインまでの距離の 2 乗を表す double 値ptSegDistSq(Point2D)
public double ptLineDist(double px, double py)
Line2D
によって定義される無限に延長された線上のもっとも近い点の間の距離です。指定された点が線と交差する場合、このメソッドは 0.0 を返します。
px
- このラインに対して測定される、指定された点の X 座標py
- このラインに対して測定される、指定された点の Y 座標
ptSegDist(double, double)
public double ptLineDist(Point2D pt)
Point2D
からこのラインまでの距離を返します。この距離は、指定された点と、この Line2D
によって定義される無限に延長された線上のもっとも近い点の間の距離です。指定された点が線と交差する場合、このメソッドは 0.0 を返します。
pt
- 測定される Point2D
Point2D
から現在のラインまでの距離を表す double 値ptSegDist(Point2D)
public boolean contains(double x, double y)
Line2D
の境界内にあるかどうかを判定します。このメソッドでは Shape
インタフェースを実装する必要があります。 ただし Line2D
オブジェクトの場合、線が領域を持つことはないため、このメソッドは常に false
を返します。
Shape
内の contains
x
- 指定された判定対象の点の X 座標y
- 指定された判定対象の点の Y 座標
false
。Line2D
が領域を持つことはないためpublic boolean contains(Point2D p)
Point2D
が、この Line2D
の境界内にあるかどうかを判定します。このメソッドでは Shape
インタフェースを実装する必要があります。 ただし Line2D
オブジェクトの場合、線が領域を持つことはないため、このメソッドは常に false
を返します。
Shape
内の contains
p
- 判定対象の、指定された Point2D
false
。Line2D
が領域を持つことはないためpublic boolean intersects(double x, double y, double w, double h)
Shape
の内部領域が、指定された矩形領域の内部領域と交差するかどうかを判定します。Shape
の内部領域と指定された矩形領域の両方に含まれる点がある場合、矩形領域は Shape
と交差していると見なされます。
Shape.intersects()
メソッドを使用すると、次のような場合に Shape
実装は true
を返すことがあります。
Shape
が重なり合っている可能性がかなり高いが、
Shape
によっては、矩形領域が Shape
と交差しない場合でもこのメソッドが true
を返すことがあります。Area
クラスは、ほとんどの Shape
オブジェクトの幾何学的な共通部分のより精密な計算を行うため、より正確な結果が必要な場合に使用できます。
Shape
内の intersects
x
- 指定された矩形領域の左上隅の X 座標y
- 指定された矩形領域の左上隅の Y 座標w
- 指定された矩形領域の幅h
- 指定された矩形領域の高さ
Shape
の内部領域と矩形領域の内部領域が交差する場合、または交差する可能性が高いが、負荷が大き過ぎて共通部分の計算を行えない場合は true
、そうでない場合は false
Area
public boolean intersects(Rectangle2D r)
Shape
の内部が、指定された Rectangle2D
の内部と交差するかどうかを判定します。Shape.intersects()
メソッドを使用すると、次のような場合に Shape
実装は true
を返すことがあります。
Rectangle2D
と Shape
が交差する可能性が高いが、
Shape
によっては、Rectangle2D
が Shape
と交差しない場合でもこのメソッドが true
を返すことがあります。Area
クラスは、ほとんどの Shape
オブジェクトの幾何学的な共通部分のより精密な計算を行うため、より正確な結果が必要な場合に使用できます。
Shape
内の intersects
r
- 指定された Rectangle2D
Shape
の内部領域と指定された Rectangle2D
の内部領域が交差する場合、または交差する可能性が高いが、負荷が大き過ぎて共通部分の計算を行えない場合は true
、そうでない場合は false
Shape.intersects(double, double, double, double)
public boolean contains(double x, double y, double w, double h)
Line2D
の内部が、指定された矩形座標セットを完全に内包するかどうかを判定します。このメソッドでは Shape
インタフェースを実装する必要があります。 ただし、Line2D
オブジェクトの場合、線が領域を持つことはないため、このメソッドは常に false
を返します。
Shape
内の contains
x
- 指定された矩形領域の左上隅の X 座標y
- 指定された矩形領域の左上隅の Y 座標w
- 指定された矩形領域の幅h
- 指定された矩形領域の高さ
false
。Line2D
が領域を持つことはないためArea
,
Shape.intersects(double, double, double, double)
public boolean contains(Rectangle2D r)
Line2D
の内部が、指定された Rectangle2D
を完全に内包するかどうかを判定します。このメソッドでは Shape
インタフェースを実装する必要があります。 ただし、Line2D
オブジェクトの場合、線が領域を持つことはないため、このメソッドは常に false
を返します。
Shape
内の contains
r
- 指定された判定対象の Rectangle2D
false
。Line2D
が領域を持つことはないためShape.contains(double, double, double, double)
public Rectangle getBounds()
Shape
を完全に囲む整数型の Rectangle
を返します。返された Rectangle
が Shape
を囲む最小のバウンディングボックスであるとは限りません。 示された Rectangle
内に Shape
が完全に収まるというだけです。また、Shape
が整数型の制限範囲を超える場合、返された Rectangle
は Shape
を完全に囲むことができないこともあります。通常は、getBounds2D
メソッドの方が、表現の自由度が高いために、比較的ぴったりしたバウンディングボックスを返します。
Shape
内の getBounds
Shape
を完全に囲む整数型の Rectangle
Shape.getBounds2D()
public PathIterator getPathIterator(AffineTransform at)
Line2D
の境界を定義する繰り返しオブジェクトを返します。このクラスの反復子は、マルチスレッドに対して安全ではありません。 つまりこの Line2D
クラスでは、この Line2D
オブジェクトの幾何学的図形を変更すると、この幾何学的図形についてすでに進行中の繰り返し処理に影響を及ぼす場合があります。
Shape
内の getPathIterator
at
- 指定された AffineTransform
Line2D
の境界を定義する PathIterator
public PathIterator getPathIterator(AffineTransform at, double flatness)
Line2D
の境界を定義する繰り返しオブジェクトを返します。このクラスの反復子は、マルチスレッドに対して安全ではありません。 つまりこの Line2D
クラスでは、この Line2D
オブジェクトの幾何学的図形を変更すると、この幾何学的図形についてすでに進行中の繰り返し処理に影響を及ぼす場合があります。
Shape
内の getPathIterator
at
- 指定された AffineTransform
flatness
- 分割された曲線が終点を結ぶ直線によって置換される前に、指定された曲線の制御点が共線から外れることのできる最大距離Line2D
オブジェクトは常に平坦であるため、このパラメータは無視される
Line2D
の境界を 定義する PathIterator
public Object clone()
Object
内の clone
OutOfMemoryError
- 十分なメモリがない場合Cloneable
|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。