Saturday, April 12, 2008

XAML - Brushes - Gradient Brushes Part 3

So for the third post of the Gradient Brushes, here is an example to how you can use the gradient brushes on test and to fill a Path object representing a triangle


Code


<StackPanel>

<TextBlock FontSize="50" Text="Sample">
<TextBlock.Foreground>
<RadialGradientBrush>
<GradientStop Offset="1" Color="Red"/>
<GradientStop Offset="0.5" Color="Purple"/>
<GradientStop Offset="0" Color="Blue"/>
</RadialGradientBrush>
</TextBlock.Foreground>
</TextBlock>

<Path Stroke="Black" Data="M 80,0 0,160 160,160 80,0">
<Path.Fill>
<RadialGradientBrush GradientOrigin="0.5,0">
<GradientStop Offset="1.5" Color="Red"/>
<GradientStop Offset="0.5" Color="Purple"/>
<GradientStop Offset="0" Color="Blue"/>
</RadialGradientBrush>
</Path.Fill>
</Path>

</StackPanel>


Screenshot

XAML - Brushes - Gradient Brushes Part 2

The RadialGradientBrush is the second type of gradient brush, the first type, LinearGradientBrush was discussed in a previous post. This brush starts with one colour at a specified postion and then changes in a circular motion to another color at a different position. There can be multiple points and colors defined.
This first example shows a three colour gradient, yellow to orange to red, starting from the default Gradient Origin located in the center of the rectangle


Code

<Rectangle Width="100" Height="60">
<Rectangle.Fill>
<RadialGradientBrush>
<GradientStop Offset="1" Color="Red"/>
<GradientStop Offset="0.5" Color="Orange"/>
<GradientStop Offset="0" Color="Yellow"/>
</RadialGradientBrush>
</Rectangle.Fill>
</Rectangle>


Screenshot



To change the starting location of the gradient, you can set the GradientOrigin property on the RadialGradientBrush tag. The example below shows the effect of setting the origin to the 0,0 position, which is the top left corner.


Code

<Rectangle Width="100" Height="60">
<Rectangle.Fill>
<RadialGradientBrush GradientOrigin="0,0">
<GradientStop Offset="1" Color="Red"/>
<GradientStop Offset="0.5" Color="Orange"/>
<GradientStop Offset="0" Color="Yellow"/>
</RadialGradientBrush>
</Rectangle.Fill>
</Rectangle>


Screenshot



Another property than can be set on the brush is the Opacity, which sets how transparent the brush colour is. A value of 0 means that it is completly transparent and 1 being completly solid. The value can be a decimal number between the two values.
Here is an example to show how this in action.


Code

<TextBlock FontSize="50">Sample</TextBlock>
<Rectangle Width="100" Height="60">
<Rectangle.Fill>
<RadialGradientBrush Opacity="0.8" GradientOrigin="0,0">
<GradientStop Offset="1" Color="Red"/>
<GradientStop Offset="0.5" Color="Orange"/>
<GradientStop Offset="0" Color="Yellow"/>
</RadialGradientBrush>
</Rectangle.Fill>
</Rectangle>


Screenshot

XAML - Brushes - Gradient Brushes Part 1

There are two gradient brush available in XAML, the RadialGradientBrush and LinearGradientBrush. I am going to show some examples how to use them both.

Firstly, to apply a brush to a visual object in XAML, you need to access the appropriate Brush property. This is likely to be either the Foreground, Background or Fill property.
This first example show how to add a linear gradient to the Fill property of a rectangle.



Code:
<Rectangle Width="100" Height="60">
<Rectangle.Fill>
<LinearGradientBrush>
<GradientStop Offset="1" Color="Red"/>
<GradientStop Offset="0.5" Color="Orange"/>
<GradientStop Offset="0" Color="Yellow"/>
</LinearGradientBrush>
</Rectangle.Fill>
</Rectangle>

Screenshot:


So as you can see from the code, the first thing we need to do is access the Fill property of the Rectangle, which we can do using the tag. Next we define the brush we want to use, in this case we use the tag. So now we are ready to choose the colours and we want to use and where they should be place. This is all done using the tag. Use the Color property to choose your colour and the Offset property to set the position.
By default the far top left of the rectangle is the 0 position and the far right bottom being 1. To set the position to some where within the recangle, you need to use a decial number between these values as done in this example, where the orange colour is set in the middle of the Rectangle at position 0.5 .
It is important to note that you can use values out side of this range, which sets the position to a hyperthetical position outside of the objects visual area. This allows for more options over the colour of the gradient without having to know the value of the colour that you want to display, lets say for instance something between red and orange. This is shown is the example below.



Code:

<Rectangle Width="100" Height="60">
<Rectangle.Fill>
<LinearGradientBrush>
<GradientStop Offset="1.5" Color="Red"/>
<GradientStop Offset="0.5" Color="Orange"/>
<GradientStop Offset="-0.5" Color="Yellow"/>
</LinearGradientBrush>
</Rectangle.Fill>
</Rectangle>

Screenshot



The gradient start and end position can be set to determine the direction of the gradient. This is achieved by setting the StartPoint and EndPoint property of the LinearGradientBrush. Again, like the Offset property, the values run from 0 to 1. Here is a diagram that should help to explain followed by an example.



Code

<Rectangle Width="100" Height="60">
<Rectangle.Fill>
<LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
<GradientStop Offset="1.5" Color="Red"/>
<GradientStop Offset="0.5" Color="Orange"/>
<GradientStop Offset="-0.5" Color="Yellow"/>
</LinearGradientBrush>
</Rectangle.Fill>
</Rectangle>
Screenshot




As this post is now getting a bit long, I will discuss the RadialGradientBrush in a future post.