public final class LinearGradientPaint extends MultipleGradientPaint
LinearGradientPaint
クラスは、Shape
をカラーの線形グラデーション・パターンで塗りつぶす方法を提供します。ユーザーはグラデーションの色を2色以上指定でき、この場合の描画では、各色の間の補間が行われます。また、ユーザー空間内で色のグラデーションの開始位置と終了位置を定義する始点と終点を指定することもできます。
ユーザーは、グラデーションでの色の分布方法を指定するfloat配列を指定する必要があります。これらの値は0.0 - 1.0の範囲内にあって、グラデーションに沿ったキー・フレームのように機能する必要があります。これらの値によって、グラデーションを厳密に特定の色にする位置をマークします。
ユーザーが最初のキー・フレーム値を0に設定しない場合や、最後のキー・フレーム値を1に設定しない場合は、キー・フレームがその位置に作成され、最初の色や最後の色がその位置に複製されます。そのため、ユーザーがグラデーションを構築するために次の配列を指定した場合、
{Color.BLUE, Color.RED}, {.3f, .7f}これは、次のキー・フレームを持つグラデーションに変換されます。
{Color.BLUE, Color.BLUE, Color.RED, Color.RED}, {0f, .3f, .7f, 1f}
ユーザーは、CycleMethod
をREFLECTION
またはREPEAT
に設定することによって、始点と終点の外側の領域を塗りつぶすときにLinearGradientPaint
オブジェクトで実行される動作を選択することもできます。反射グラデーションまたは繰返しグラデーションでは、1つのグラデーションの中にある任意の2色の間の距離は、始点と終点の間のそれら2色の距離と同じになります。ピクセルの粒度でのサンプリングのために、間隔にわずかな変動がいくつか発生する可能性があることに注意してください。循環方法を指定しない場合は、デフォルトでNO_CYCLE
が選択されます。つまり、残りの領域を塗りつぶすために端点の色が使用されます。
colorSpaceパラメータでは、補間が実行されるカラー・スペース(デフォルトのsRGBまたは線形化されたRGB)を指定できます。
次のコードは、LinearGradientPaint
の一般的な使い方を示しています。
Point2D start = new Point2D.Float(0, 0); Point2D end = new Point2D.Float(50, 50); float[] dist = {0.0f, 0.2f, 1.0f}; Color[] colors = {Color.RED, Color.WHITE, Color.BLUE}; LinearGradientPaint p = new LinearGradientPaint(start, end, dist, colors);
このコードにより、LinearGradientPaint
が作成され、グラデーションの最初の20%は赤と白の間で補間され、残りの80%は白と青の間で補間されます。
3つの循環方法のそれぞれについて、上記のコード例の結果は次のイメージのようになります。
Paint
, Graphics2D.setPaint(java.awt.Paint)
MultipleGradientPaint.ColorSpaceType, MultipleGradientPaint.CycleMethod
BITMASK, OPAQUE, TRANSLUCENT
コンストラクタと説明 |
---|
LinearGradientPaint(float startX, float startY, float endX, float endY, float[] fractions, Color[] colors)
デフォルトの
NO_CYCLE 繰返しメソッドとSRGB カラー・スペースでLinearGradientPaint を構築します。 |
LinearGradientPaint(float startX, float startY, float endX, float endY, float[] fractions, Color[] colors, MultipleGradientPaint.CycleMethod cycleMethod)
デフォルトの
SRGB カラー・スペースでLinearGradientPaint を構築します。 |
LinearGradientPaint(Point2D start, Point2D end, float[] fractions, Color[] colors)
デフォルトの
NO_CYCLE 繰返しメソッドとSRGB カラー・スペースでLinearGradientPaint を構築します。 |
LinearGradientPaint(Point2D start, Point2D end, float[] fractions, Color[] colors, MultipleGradientPaint.CycleMethod cycleMethod)
デフォルトの
SRGB カラー・スペースでLinearGradientPaint を構築します。 |
LinearGradientPaint(Point2D start, Point2D end, float[] fractions, Color[] colors, MultipleGradientPaint.CycleMethod cycleMethod, MultipleGradientPaint.ColorSpaceType colorSpace, AffineTransform gradientTransform)
LinearGradientPaint を構築します。 |
修飾子と型 | メソッドと説明 |
---|---|
PaintContext |
createContext(ColorModel cm, Rectangle deviceBounds, Rectangle2D userBounds, AffineTransform transform, RenderingHints hints)
カラーの線形グラデーション・パターンを生成するために使用される
PaintContext を作成して返します。 |
Point2D |
getEndPoint()
放射状グラデーションの焦点のコピーを返します。
|
Point2D |
getStartPoint()
グラデーション軸の始点のコピーを返します。
|
getColors, getColorSpace, getCycleMethod, getFractions, getTransform, getTransparency
public LinearGradientPaint(float startX, float startY, float endX, float endY, float[] fractions, Color[] colors)
NO_CYCLE
繰返しメソッドとSRGB
カラー・スペースでLinearGradientPaint
を構築します。startX
- ユーザー空間内のグラデーション軸の始点のX座標startY
- ユーザー空間内のグラデーション軸の始点のY座標endX
- ユーザー空間内のグラデーション軸の終点のX座標endY
- ユーザー空間内のグラデーション軸の終点のY座標fractions
- グラデーションに沿った色の分布を指定する、0.0から1.0までの範囲の数値colors
- 各小数値に対応する色の配列NullPointerException
- fractions
配列がnullであるか、colors
配列がnullである場合IllegalArgumentException
- 始点と終点が同じ点である場合、fractions.length != colors.length
である場合、colors
のサイズが2がより小さい場合、fractions
値が0.0より小さいか1.0より大きい場合、またはfractions
が厳密に昇順で指定されていない場合public LinearGradientPaint(float startX, float startY, float endX, float endY, float[] fractions, Color[] colors, MultipleGradientPaint.CycleMethod cycleMethod)
SRGB
カラー・スペースでLinearGradientPaint
を構築します。startX
- ユーザー空間内のグラデーション軸の始点のX座標startY
- ユーザー空間内のグラデーション軸の始点のY座標endX
- ユーザー空間内のグラデーション軸の終点のX座標endY
- ユーザー空間内のグラデーション軸の終点のY座標fractions
- グラデーションに沿った色の分布を指定する、0.0から1.0までの範囲の数値colors
- 各小数値に対応する色の配列cycleMethod
- NO_CYCLE
、REFLECT
、REPEAT
のいずれかNullPointerException
- fractions
配列がnullであるか、colors
配列がnullであるか、またはcycleMethod
がnullである場合IllegalArgumentException
- 始点と終点が同じ点である場合、fractions.length != colors.length
である場合、colors
のサイズが2がより小さい場合、fractions
値が0.0より小さいか1.0より大きい場合、またはfractions
が厳密に昇順で指定されていない場合public LinearGradientPaint(Point2D start, Point2D end, float[] fractions, Color[] colors)
NO_CYCLE
繰返しメソッドとSRGB
カラー・スペースでLinearGradientPaint
を構築します。start
- ユーザー空間内のグラデーション軸の始点Point2D
end
- ユーザー空間内のグラデーション軸の終点Point2D
fractions
- グラデーションに沿った色の分布を指定する、0.0から1.0までの範囲の数値colors
- 各小数値に対応する色の配列NullPointerException
- いずれかの点がnullの場合、fractions
配列がnullの場合、またはcolors
配列がnullの場合IllegalArgumentException
- 始点と終点が同じ点である場合、fractions.length != colors.length
である場合、colors
のサイズが2がより小さい場合、fractions
値が0.0より小さいか1.0より大きい場合、またはfractions
が厳密に昇順で指定されていない場合public LinearGradientPaint(Point2D start, Point2D end, float[] fractions, Color[] colors, MultipleGradientPaint.CycleMethod cycleMethod)
SRGB
カラー・スペースでLinearGradientPaint
を構築します。start
- ユーザー空間内のグラデーション軸の始点Point2D
end
- ユーザー空間内のグラデーション軸の終点Point2D
fractions
- グラデーションに沿った色の分布を指定する、0.0から1.0までの範囲の数値colors
- 各小数値に対応する色の配列cycleMethod
- NO_CYCLE
、REFLECT
、REPEAT
のいずれかNullPointerException
- いずれかの点がnullであるか、fractions
配列がnullであるか、colors
配列がnullであるか、またはcycleMethod
がnullである場合IllegalArgumentException
- 始点と終点が同じ点である場合、fractions.length != colors.length
である場合、colors
のサイズが2がより小さい場合、fractions
値が0.0より小さいか1.0より大きい場合、またはfractions
が厳密に昇順で指定されていない場合@ConstructorProperties(value={"startPoint","endPoint","fractions","colors","cycleMethod","colorSpace","transform"}) public LinearGradientPaint(Point2D start, Point2D end, float[] fractions, Color[] colors, MultipleGradientPaint.CycleMethod cycleMethod, MultipleGradientPaint.ColorSpaceType colorSpace, AffineTransform gradientTransform)
LinearGradientPaint
を構築します。start
- ユーザー空間内のグラデーション軸の始点Point2D
end
- ユーザー空間内のグラデーション軸の終点Point2D
fractions
- グラデーションに沿った色の分布を指定する、0.0から1.0までの範囲の数値colors
- 各小数値に対応する色の配列cycleMethod
- NO_CYCLE
、REFLECT
、REPEAT
のいずれかcolorSpace
- 補間に使用するカラー・スペースであり、SRGB
またはLINEAR_RGB
のどちらかgradientTransform
- グラデーションに適用する変換NullPointerException
- いずれかの点がnullであるか、fractions
配列がnullであるか、colors
配列がnullであるか、cycleMethod
がnullであるか、colorSpace
がnullであるか、またはgradientTransform
がnullである場合IllegalArgumentException
- 始点と終点が同じ点である場合、fractions.length != colors.length
である場合、colors
のサイズが2がより小さい場合、fractions
値が0.0より小さいか1.0より大きい場合、またはfractions
が厳密に昇順で指定されていない場合public PaintContext createContext(ColorModel cm, Rectangle deviceBounds, Rectangle2D userBounds, AffineTransform transform, RenderingHints hints)
PaintContext
を作成して返します。nullパラメータの処理については、Paint
インタフェース内のメソッドのspecification
を参照してください。cm
- 呼出し元がピクセル・データを受信するためのもっとも便利な形式を表す推奨されるColorModel
、または推奨値がない場合はnull
。deviceBounds
- 描画されるグラフィックス・プリミティブのデバイス空間でのバウンディング・ボックス。userBounds
- 描画されるグラフィックス・プリミティブのユーザー空間でのバウンディング・ボックス。transform
- ユーザー空間からデバイス空間へのAffineTransform
。hints
- コンテキスト・オブジェクトが描画の選択肢の中から選択するために使用できるヒントのセット。PaintContext
。Paint
, PaintContext
, ColorModel
, Rectangle
, Rectangle2D
, AffineTransform
, RenderingHints
public Point2D getStartPoint()
LinearGradientPaint
の最初の色を固定する点のコピーを表すPoint2D
オブジェクトpublic Point2D getEndPoint()
LinearGradientPaint
の最後の色を固定する点のコピーを表すPoint2D
オブジェクト バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright© 1993, 2014, Oracle and/or its affiliates. All rights reserved.