Introduction
Brushesand pens are objects used to draw and fill graphics objects. In this
article, I will discuss various types of brushes available in XAML and
WPF model, their members, and properties and how to use them in your
applications.
WPFand XAML work together and there is an WPF class corresponding to each
XAML control. For example, <SolidColorBrush> tag in XAML and
SolidColorBrush class in WPF, both represent the solid color brush. You
can create and use brushes in both ways seperately or mix them. For
example, I can create a brush using XAML and then later set the same
brushes property dynamically in my coding using WPF class model.
In XAML and WPF model provides following brush objects -
- SolidColorBrush
- LinearGradientBrush
- RadialGradientBrush
- DrawingBrush
- Visual Brush
- ImageBrush
1. Solid Color Brush
The<SolidColorBrush/> represents the solid color brush in XAML. The
Color attribute of the tag represents the color used in the brush. For
example, the following code creates a solid color brush with blue color.
<SolidColorBrush Color="Blue" />
The Color attribute can also be a hex value instead of the color name. The following code uses hex value of a color.
<SolidColorBrush Color="#FFFFFF" />
The following code fills a rectangle with black color.
<Rectangle Width="200" Height="40" Stroke="Blue" StrokeThickness="1">
<Rectangle.Fill>
<SolidColorBrush Color="#000000" />
</Rectangle.Fill>
</Rectangle>
The output looks like Figure 1, which is a filled rectangle with black color.

Figure 1. Rectangle with a solid brush
2. Linear Gradient Brush
The <LinearGradientBrush> object represents the linear gradient brush in XAML.
The following source code draws a rectangle and fills with a linear gradient brush of red and green colors.
<Rectangle Width="200" Height="40" Stroke="Blue" StrokeThickness="3">
<Rectangle.Fill>
<LinearGradientBrush>
<GradientStop Offset="0" Color="Red"/>
<GradientStop Offset="1" Color="Green"/>
</LinearGradientBrush>
</Rectangle.Fill>
</Rectangle>
The output looks like Figure 2.

Figure 2. Rectangle filled with a linear gradient brush.
3. Radial Gradient Brush
The <RadialGradientBrush/>represents the radial gradient brush in XAML. Radial gradient brush
provides gradient similar to linear gradient brush, however a linear
gradient brush has a start point and end point and blending is done fromthe start and ending, while radial gradient brush has a circle.
Ina radial gradient brush, you specify the gradient origin, center, and
circle's X,Y radus values and GradientStop attribute specify the color
of the graident.
The following source code draws a rectangle and fills with a radial gradient brush with multiple colors.
<Rectangle Width="300" Height="300" Stroke="Black" StrokeThickness="2">
<Rectangle.Fill>
<RadialGradientBrush GradientOrigin="0.1,0.4" Center="0.6,0.5" RadiusX="0.5" RadiusY="0.5">
<GradientStop Color="Red" Offset="0" />
<GradientStop Color="Black" Offset="0.20" />
<GradientStop Color="Yellow" Offset="0.40" />
<GradientStop Color="Pink" Offset="0.60" />
<GradientStop Color="Blue" Offset="0.80" />
<GradientStop Color="Green" Offset="1.0" />
</RadialGradientBrush>
</Rectangle.Fill>
</Rectangle>
The output looks like Figure 3.

Figure 3. Rectangle filled with a radial gradient brush
4. Drawing Brush
DrawingBrush is a new addition to the brush types since GDI+. A Drawing Brushcan be used to paint an area with shapes, text, images, and even video.The <DrawingBrush/> represents the drawing brush in XAML. A
Drawing Brush uses drawing objects GeomertyDrawing, ImageDrawing,
VideoDrawing, and GylphRunDrawing to draw shapes, images, video, and
text respectively.
Thefollowing code uses a DrawingBrush to fill two ellipses. I will cover
DrawingBrush objects, its methods and properties in more details in my
seperate article.
<Rectangle Width="300" Height="300" Stroke="Black" StrokeThickness="2">
<Rectangle.Fill>
<DrawingBrush>
<DrawingBrush.Drawing>
<GeometryDrawing Brush="Green">
<GeometryDrawing.Geometry>
<GeometryGroup>
<EllipseGeometry RadiusX="0.1" RadiusY="0.5" Center="0.5,0.5" />
<EllipseGeometry RadiusX="0.5" RadiusY="0.1" Center="0.5,0.5" />
</GeometryGroup>
</GeometryDrawing.Geometry>
</GeometryDrawing>
</DrawingBrush.Drawing>
</DrawingBrush>
</Rectangle.Fill>
</Rectangle>
The output looks like Figure 4.

Figure 4. Rectangle filled with a drawing brush
5. Visual Brush
VisualBrushis a new addition to the brush types since GDI+. A VisualBrush is usedto fill UI elements. The following code uses a VisualBrush to fill a
rectangle. I will cover VisualBrush object, its methods and properties
in more details in my seperate article.
<Rectangle Width="200" Height="100">
<Rectangle.Fill>
<VisualBrush TileMode="Tile">
<VisualBrush.Visual>
<StackPanel>
<StackPanel.Background>
<DrawingBrush>
<DrawingBrush.Drawing>
<GeometryDrawing>
<GeometryDrawing.Brush>
<RadialGradientBrush>
<GradientStop Color="Green" Offset="0.0" />
<GradientStop Color="White" Offset="1.0" />
</RadialGradientBrush>
</GeometryDrawing.Brush>
<GeometryDrawing.Geometry>
<GeometryGroup>
<RectangleGeometry Rect="0,0,50,50" />
<RectangleGeometry Rect="50,50,50,50" />
</GeometryGroup>
</GeometryDrawing.Geometry>
</GeometryDrawing>
</DrawingBrush.Drawing>
</DrawingBrush>
</StackPanel.Background>
<TextBlock FontSize="14pt" FontWeight="Bold" Margin="10">Visual Brush</TextBlock>
</StackPanel>
</VisualBrush.Visual>
</VisualBrush>
</Rectangle.Fill>
</Rectangle>
The output looks like Figure 5.

Figure 5. Rectangle filled with a visual brush
Learn more about Visual Brushes here: Visual Brush in WPF by Raj Kumar.
6. Image Brush
Animage brush uses an image as fill color to fill graphics objects such
as a recntagle, ellipse, and path. The <ImageBrush/> represents
the image brush in XAML. The BitmapSource property represents the imageused to fill the brush.
For example, the following code fills a rectangle with an ImageBrush.
<Rectangle Width="100" Height="100" Stroke="Black" StrokeThickness="3">
<Rectangle.Fill>
<ImageBrush ImageSource="Milk.jpg"/>
</Rectangle.Fill>
</Rectangle>
The output looks like Figure 6.

Image 6. Rectangle with an image brush.
Summary
Inthis article, I discussed brushes available in XAML and WPF model.
Clearly, there have been some improvements and additions in brushes
in XAML and WPF model since GDI+.