次の方法で共有


PathGradientBrush.ScaleTransform メソッド

指定した分量だけローカル ジオメトリック変換をスケールします。このメソッドは変換の前にスケーリング行列を適用します。

オーバーロードの一覧

指定した分量だけローカル ジオメトリック変換をスケールします。このメソッドは変換の前にスケーリング行列を適用します。

[Visual Basic] Overloads Public Sub ScaleTransform(Single, Single)

[C#] public void ScaleTransform(float, float);

[C++] public: void ScaleTransform(float, float);

[JScript] public function ScaleTransform(float, float);

指定した順序で、指定した分量だけローカル ジオメトリック変換をスケールします。

[Visual Basic] Overloads Public Sub ScaleTransform(Single, Single, MatrixOrder)

[C#] public void ScaleTransform(float, float, MatrixOrder);

[C++] public: void ScaleTransform(float, float, MatrixOrder);

[JScript] public function ScaleTransform(float, float, MatrixOrder);

使用例

[Visual Basic, C#] 次の例は、Windows フォームでの使用を意図してデザインされており、 OnPaint イベントのオブジェクトである PaintEventArgs e が必要です。このコードは次のアクションを実行します。

  • グラフィックス パスを作成し、そのパスに四角形を追加します。
  • パスを形成する複数の点から PathGradientBrush オブジェクトを作成します。この例では、これらの点は四角形を形成していますが、どのような図形を形成する点でもかまいません。
  • 中心の色を赤に設定し、周囲の色を青に設定します。
  • スケール変換を適用する前に、 PathGradientBrush を画面に描画します。
  • ブラシの ScaleTransform メソッドを使用して、そのブラシにスケール変換を適用します。
  • TranslateTransform メソッドを呼び出して、画面に先に描画された四角形と重複しないように、ブラシ四角形を移動します。
  • 平行移動後のブラシの四角形を画面に描画します。

[Visual Basic, C#] 下側の四角形は、平行移動前に描画された四角形と比較して、x 軸方向の辺の長さが 2 倍になっています。

[Visual Basic, C#] メモ   ここでは、ScaleTransform のオーバーロード形式のうちの 1 つだけについて、使用例を示します。その他の例については、各オーバーロード形式のトピックを参照してください。

 
Public Sub ScaleTransformExample(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 transformation.
e.Graphics.FillRectangle(myPGBrush, 10, 10, 200, 200)
' Scale by a factor of 2 in the x-axis by applying the scale
' transform to the brush.
myPGBrush.ScaleTransform(2, 1, MatrixOrder.Append)
' Move the brush down by 100 by Applying the translate
' transform to the brush.
myPGBrush.TranslateTransform(- 100, 100, MatrixOrder.Append)
' Draw the brush to the screen again after applying the
' transforms.
e.Graphics.FillRectangle(myPGBrush, 10, 10, 300, 300)
End Sub
        
[C#] 
public void ScaleTransformExample(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 transformation.
e.Graphics.FillRectangle(myPGBrush, 10, 10, 200, 200);
// Scale by a factor of 2 in the x-axis by applying the scale
// transform to the brush.
myPGBrush.ScaleTransform(2, 1, MatrixOrder.Append);
// Move the brush down by 100 by Applying the translate
// transform to the brush.
myPGBrush.TranslateTransform(-100, 100, MatrixOrder.Append);
// Draw the brush to the screen again after applying the
// transforms.
e.Graphics.FillRectangle(myPGBrush, 10, 10, 300, 300);
}
        

[C++, JScript] C++ および JScript のサンプルはありません。Visual Basic および C# のサンプルを表示するには、このページの左上隅にある言語のフィルタ ボタン 言語のフィルタ をクリックします。

参照

PathGradientBrush クラス | PathGradientBrush メンバ | System.Drawing.Drawing2D 名前空間