2 // System.Drawing.Drawing2D.LinearGradientBrush.cs
5 // Dennis Hayes (dennish@Raytek.com)
6 // Ravindra (rkumar@novell.com)
8 // Copyright (C) 2002/3 Ximian, Inc. http://www.ximian.com
9 // Copyright (C) 2004,2006 Novell, Inc (http://www.novell.com)
11 // Permission is hereby granted, free of charge, to any person obtaining
12 // a copy of this software and associated documentation files (the
13 // "Software"), to deal in the Software without restriction, including
14 // without limitation the rights to use, copy, modify, merge, publish,
15 // distribute, sublicense, and/or sell copies of the Software, and to
16 // permit persons to whom the Software is furnished to do so, subject to
17 // the following conditions:
19 // The above copyright notice and this permission notice shall be
20 // included in all copies or substantial portions of the Software.
22 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
23 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
25 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
26 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
27 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
31 using System.ComponentModel;
33 namespace System.Drawing.Drawing2D {
35 public sealed class LinearGradientBrush : Brush
39 internal LinearGradientBrush (IntPtr native) : base (native)
41 Status status = GDIPlus.GdipGetLineRect (native, out rectangle);
42 GDIPlus.CheckStatus (status);
45 public LinearGradientBrush (Point point1, Point point2, Color color1, Color color2)
47 Status status = GDIPlus.GdipCreateLineBrushI (ref point1, ref point2, color1.ToArgb (), color2.ToArgb (), WrapMode.Tile, out nativeObject);
48 GDIPlus.CheckStatus (status);
50 status = GDIPlus.GdipGetLineRect (nativeObject, out rectangle);
51 GDIPlus.CheckStatus (status);
54 public LinearGradientBrush (PointF point1, PointF point2, Color color1, Color color2)
56 Status status = GDIPlus.GdipCreateLineBrush (ref point1, ref point2, color1.ToArgb (), color2.ToArgb (), WrapMode.Tile, out nativeObject);
57 GDIPlus.CheckStatus (status);
59 status = GDIPlus.GdipGetLineRect (nativeObject, out rectangle);
60 GDIPlus.CheckStatus (status);
63 public LinearGradientBrush (Rectangle rect, Color color1, Color color2, LinearGradientMode linearGradientMode)
65 Status status = GDIPlus.GdipCreateLineBrushFromRectI (ref rect, color1.ToArgb (), color2.ToArgb (), linearGradientMode, WrapMode.Tile, out nativeObject);
66 GDIPlus.CheckStatus (status);
68 rectangle = (RectangleF) rect;
71 public LinearGradientBrush (Rectangle rect, Color color1, Color color2, float angle) : this (rect, color1, color2, angle, false)
75 public LinearGradientBrush (RectangleF rect, Color color1, Color color2, LinearGradientMode linearGradientMode)
77 Status status = GDIPlus.GdipCreateLineBrushFromRect (ref rect, color1.ToArgb (), color2.ToArgb (), linearGradientMode, WrapMode.Tile, out nativeObject);
78 GDIPlus.CheckStatus (status);
83 public LinearGradientBrush (RectangleF rect, Color color1, Color color2, float angle) : this (rect, color1, color2, angle, false)
87 public LinearGradientBrush (Rectangle rect, Color color1, Color color2, float angle, bool isAngleScaleable)
89 Status status = GDIPlus.GdipCreateLineBrushFromRectWithAngleI (ref rect, color1.ToArgb (), color2.ToArgb (), angle, isAngleScaleable, WrapMode.Tile, out nativeObject);
90 GDIPlus.CheckStatus (status);
92 rectangle = (RectangleF) rect;
95 public LinearGradientBrush (RectangleF rect, Color color1, Color color2, float angle, bool isAngleScaleable)
97 Status status = GDIPlus.GdipCreateLineBrushFromRectWithAngle (ref rect, color1.ToArgb (), color2.ToArgb (), angle, isAngleScaleable, WrapMode.Tile, out nativeObject);
98 GDIPlus.CheckStatus (status);
108 Status status = GDIPlus.GdipGetLineBlendCount (nativeObject, out count);
109 GDIPlus.CheckStatus (status);
110 float [] factors = new float [count];
111 float [] positions = new float [count];
112 status = GDIPlus.GdipGetLineBlend (nativeObject, factors, positions, count);
113 GDIPlus.CheckStatus (status);
115 Blend blend = new Blend ();
116 blend.Factors = factors;
117 blend.Positions = positions;
123 float [] factors = value.Factors;
124 float [] positions = value.Positions;
125 count = factors.Length;
127 if (count == 0 || positions.Length == 0)
128 throw new ArgumentException ("Invalid Blend object. It should have at least 2 elements in each of the factors and positions arrays.");
130 if (count != positions.Length)
131 throw new ArgumentException ("Invalid Blend object. It should contain the same number of factors and positions values.");
133 if (positions [0] != 0.0F)
134 throw new ArgumentException ("Invalid Blend object. The positions array must have 0.0 as its first element.");
136 if (positions [count - 1] != 1.0F)
137 throw new ArgumentException ("Invalid Blend object. The positions array must have 1.0 as its last element.");
139 Status status = GDIPlus.GdipSetLineBlend (nativeObject, factors, positions, count);
140 GDIPlus.CheckStatus (status);
144 [MonoTODO ("Not used inside libgdiplus")]
145 public bool GammaCorrection {
147 bool gammaCorrection;
148 Status status = GDIPlus.GdipGetLineGammaCorrection (nativeObject, out gammaCorrection);
149 GDIPlus.CheckStatus (status);
150 return gammaCorrection;
153 Status status = GDIPlus.GdipSetLineGammaCorrection (nativeObject, value);
154 GDIPlus.CheckStatus (status);
158 public ColorBlend InterpolationColors {
161 Status status = GDIPlus.GdipGetLinePresetBlendCount (nativeObject, out count);
162 GDIPlus.CheckStatus (status);
163 int [] intcolors = new int [count];
164 float [] positions = new float [count];
165 status = GDIPlus.GdipGetLinePresetBlend (nativeObject, intcolors, positions, count);
166 GDIPlus.CheckStatus (status);
168 ColorBlend interpolationColors = new ColorBlend ();
169 Color [] colors = new Color [count];
170 for (int i = 0; i < count; i++)
171 colors [i] = Color.FromArgb (intcolors [i]);
172 interpolationColors.Colors = colors;
173 interpolationColors.Positions = positions;
175 return interpolationColors;
179 Color [] colors = value.Colors;
180 float [] positions = value.Positions;
181 count = colors.Length;
183 if (count == 0 || positions.Length == 0)
184 throw new ArgumentException ("Invalid ColorBlend object. It should have at least 2 elements in each of the colors and positions arrays.");
186 if (count != positions.Length)
187 throw new ArgumentException ("Invalid ColorBlend object. It should contain the same number of positions and color values.");
189 if (positions [0] != 0.0F)
190 throw new ArgumentException ("Invalid ColorBlend object. The positions array must have 0.0 as its first element.");
192 if (positions [count - 1] != 1.0F)
193 throw new ArgumentException ("Invalid ColorBlend object. The positions array must have 1.0 as its last element.");
195 int [] blend = new int [colors.Length];
196 for (int i = 0; i < colors.Length; i++)
197 blend [i] = colors [i].ToArgb ();
199 Status status = GDIPlus.GdipSetLinePresetBlend (nativeObject, blend, positions, count);
200 GDIPlus.CheckStatus (status);
204 public Color [] LinearColors {
206 int [] colors = new int [2];
207 Status status = GDIPlus.GdipGetLineColors (nativeObject, colors);
208 GDIPlus.CheckStatus (status);
209 Color [] linearColors = new Color [2];
210 linearColors [0] = Color.FromArgb (colors [0]);
211 linearColors [1] = Color.FromArgb (colors [1]);
216 Status status = GDIPlus.GdipSetLineColors (nativeObject, value [0].ToArgb (), value [1].ToArgb ());
217 GDIPlus.CheckStatus (status);
221 public RectangleF Rectangle {
227 public Matrix Transform {
229 Matrix matrix = new Matrix ();
230 Status status = GDIPlus.GdipGetLineTransform (nativeObject, matrix.nativeMatrix);
231 GDIPlus.CheckStatus (status);
237 throw new ArgumentNullException ("Transform");
239 Status status = GDIPlus.GdipSetLineTransform (nativeObject, value.nativeMatrix);
240 GDIPlus.CheckStatus (status);
244 public WrapMode WrapMode {
247 Status status = GDIPlus.GdipGetLineWrapMode (nativeObject, out wrapMode);
248 GDIPlus.CheckStatus (status);
253 // note: Clamp isn't valid (context wise) but it is checked in libgdiplus
254 if ((value < WrapMode.Tile) || (value > WrapMode.Clamp))
255 throw new InvalidEnumArgumentException ("WrapMode");
257 Status status = GDIPlus.GdipSetLineWrapMode (nativeObject, value);
258 GDIPlus.CheckStatus (status);
264 public void MultiplyTransform (Matrix matrix)
266 MultiplyTransform (matrix, MatrixOrder.Prepend);
269 public void MultiplyTransform (Matrix matrix, MatrixOrder order)
272 throw new ArgumentNullException ("matrix");
274 Status status = GDIPlus.GdipMultiplyLineTransform (nativeObject, matrix.nativeMatrix, order);
275 GDIPlus.CheckStatus (status);
278 public void ResetTransform ()
280 Status status = GDIPlus.GdipResetLineTransform (nativeObject);
281 GDIPlus.CheckStatus (status);
284 public void RotateTransform (float angle)
286 RotateTransform (angle, MatrixOrder.Prepend);
289 public void RotateTransform (float angle, MatrixOrder order)
291 Status status = GDIPlus.GdipRotateLineTransform (nativeObject, angle, order);
292 GDIPlus.CheckStatus (status);
295 public void ScaleTransform (float sx, float sy)
297 ScaleTransform (sx, sy, MatrixOrder.Prepend);
300 public void ScaleTransform (float sx, float sy, MatrixOrder order)
302 Status status = GDIPlus.GdipScaleLineTransform (nativeObject, sx, sy, order);
303 GDIPlus.CheckStatus (status);
306 public void SetBlendTriangularShape (float focus)
308 SetBlendTriangularShape (focus, 1.0F);
311 public void SetBlendTriangularShape (float focus, float scale)
313 if (focus < 0 || focus > 1 || scale < 0 || scale > 1)
314 throw new ArgumentException ("Invalid parameter passed.");
316 Status status = GDIPlus.GdipSetLineLinearBlend (nativeObject, focus, scale);
317 GDIPlus.CheckStatus (status);
320 public void SetSigmaBellShape (float focus)
322 SetSigmaBellShape (focus, 1.0F);
325 public void SetSigmaBellShape (float focus, float scale)
327 if (focus < 0 || focus > 1 || scale < 0 || scale > 1)
328 throw new ArgumentException ("Invalid parameter passed.");
330 Status status = GDIPlus.GdipSetLineSigmaBlend (nativeObject, focus, scale);
331 GDIPlus.CheckStatus (status);
334 public void TranslateTransform (float dx, float dy)
336 TranslateTransform (dx, dy, MatrixOrder.Prepend);
339 public void TranslateTransform (float dx, float dy, MatrixOrder order)
341 Status status = GDIPlus.GdipTranslateLineTransform (nativeObject, dx, dy, order);
342 GDIPlus.CheckStatus (status);
345 public override object Clone ()
348 Status status = GDIPlus.GdipCloneBrush (nativeObject, out clonePtr);
349 GDIPlus.CheckStatus (status);
351 return new LinearGradientBrush (clonePtr);