釣鐘型の曲線に基づいて、中心の色から最初の周囲の色に向かって減色していくグラデーションを作成します。
オーバーロードの一覧
パスの中心から境界へと外側に向かって色が変化していくグラデーション ブラシを作成します。色は、釣鐘型の曲線に基づいて、ある色から別の色へと変化していきます。
[Visual Basic] Overloads Public Sub SetSigmaBellShape(Single)
パスの中心から境界へと外側に向かって色が変化していくグラデーション ブラシを作成します。色は、釣鐘型の曲線に基づいて、ある色から別の色へと変化していきます。
[Visual Basic] Overloads Public Sub SetSigmaBellShape(Single, Single)
使用例
[Visual Basic, C#] 次の例は、Windows フォームでの使用を意図してデザインされており、 OnPaint イベントのオブジェクトである PaintEventArgs e が必要です。このコードは次のアクションを実行します。
- グラフィックス パスを作成し、そのパスに四角形を追加します。
- パスを形成する複数の点から PathGradientBrush を作成します。この例では、これらの点は四角形を形成していますが、どのような図形を形成する点でもかまいません。
- 中心の色を赤に設定し、周囲の色を青に設定します。
- ブレンド変換を適用する前に、 PathGradientBrush を画面に描画します。
- ブラシの SetSigmaBellShape メソッドを使用して、そのブラシにブレンド変換を適用します。
- TranslateTransform メソッドを呼び出して、画面に先に描画された四角形と重複しないように、ブラシ四角形を移動します。
- 変換後のブラシの四角形を画面に描画します。
[Visual Basic, C#] 中心の色 (赤) の輝度が最大になるのは、パスの中心から境界に向かう距離の半分の位置です。
[Visual Basic, C#] メモ ここでは、SetSigmaBellShape のオーバーロード形式のうちの 1 つだけについて、使用例を示します。その他の例については、各オーバーロード形式のトピックを参照してください。
Public Sub SetSigmaBellShapeExample(e As PaintEventArgs)
' Create a graphics path and add a rectangle.
Dim myPath As New GraphicsPath()
Dim rect As New Rectangle(100, 20, 100, 50)
myPath.AddRectangle(rect)
' Get the path's array of points.
Dim myPathPointArray As PointF() = myPath.PathPoints
' Create a path gradient brush.
Dim myPGBrush As New PathGradientBrush(myPathPointArray)
' Set the color span.
myPGBrush.CenterColor = Color.Red
Dim mySurroundColor As Color() = {Color.Blue}
myPGBrush.SurroundColors = mySurroundColor
' Draw the brush to the screen prior to blend.
e.Graphics.FillRectangle(myPGBrush, 10, 10, 200, 200)
' Set the Blend factors.
myPGBrush.SetSigmaBellShape(0.5F, 1F)
' Move the brush down by 100 by applying the translate
' transform to the brush.
myPGBrush.TranslateTransform(0, 100, MatrixOrder.Append)
' Draw the brush to the screen again after setting the
' blend and applying the transform.
e.Graphics.FillRectangle(myPGBrush, 10, 10, 300, 300)
End Sub
[C#]
public void SetSigmaBellShapeExample(PaintEventArgs e)
{
// Create a graphics path and add a rectangle.
GraphicsPath myPath = new GraphicsPath();
Rectangle rect = new Rectangle(100, 20, 100, 50);
myPath.AddRectangle(rect);
// Get the path's array of points.
PointF[] myPathPointArray = myPath.PathPoints;
// Create a path gradient brush.
PathGradientBrush myPGBrush = new
PathGradientBrush(myPathPointArray);
// Set the color span.
myPGBrush.CenterColor = Color.Red;
Color[] mySurroundColor = {Color.Blue};
myPGBrush.SurroundColors = mySurroundColor;
// Draw the brush to the screen prior to blend.
e.Graphics.FillRectangle(myPGBrush, 10, 10, 200, 200);
// Set the Blend factors and transform the brush.
myPGBrush.SetSigmaBellShape(0.5f, 1.0f);
// Move the brush down by 100 by applying the translate
// transform to the brush.
myPGBrush.TranslateTransform(0, 100, MatrixOrder.Append);
// Draw the brush to the screen again after setting the
// blend and applying the transform.
e.Graphics.FillRectangle(myPGBrush, 10, 10, 300, 300);
}
[C++, JScript] C++ および JScript のサンプルはありません。Visual Basic および C# のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン をクリックします。
参照
PathGradientBrush クラス | PathGradientBrush メンバ | System.Drawing.Drawing2D 名前空間