Control Templates allow the look and feel of Controls in Silverlight allowing for a flexible user experience.
Here is the Hello World example using a Control Template and the Visual State Manager to Customise the Button.
Printer Friendly Download Tutorial (214KB) Download Source Code (6.67KB) Online Demonstration
Step 1
Start Microsoft Visual Web Developer 2010 Express, then Select File then New Project... Select "Visual Basic" then "Silverlight Application" from Templates, select a Location if you wish, then enter a name for the Project and then click OK, see below:
data:image/s3,"s3://crabby-images/bbec6/bbec6766da8b1677089c6d093b615cf7dc02f8d9" alt="New Project"
Step 2
New Silverlight Application window should appear, uncheck the box "Host the Silverlight Application in a new Web site" and then select the required Silverlight Version, see below:
data:image/s3,"s3://crabby-images/a5adb/a5adb615c2cdbf74381ac03397bb94e9b0a3bbbe" alt="New Silverlight Application"
Step 3
A Blank Page named MainPage.xaml should then appear, see below:
data:image/s3,"s3://crabby-images/607db/607db0ef20ef4c36d5f145968e319a4292fd54b3" alt="MainPage.xaml"
Step 4
In the XAML Pane for the MainPage.xaml, below the "x:Class="ControlTemplate.MainPage" section, type the following XAML:
xmlns:vsm="clr-namespace:System.Windows;assembly=System.Windows"
See below:
data:image/s3,"s3://crabby-images/9c06c/9c06c0364bf3dd08e07d01538b0957b2b1a72d93" alt="MainPage Namespaces"
Step 5
While still the XAML Pane for the MainPage.xaml, above the "<Grid>" and below the top "<UserControl>" tag, type the following XAML:
<UserControl.Resources>
<Style x:Key="CircleButton" TargetType="Button">
<Setter Property="Foreground" Value="White"/>
<Setter Property="FontWeight" Value="Bold"/>
<Setter Property="Background">
<Setter.Value>
<LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
<GradientStop Offset="0" Color="#FFFF281E"/>
<GradientStop Offset="1" Color="#FFFA9024"/>
</LinearGradientBrush>
</Setter.Value>
</Setter>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Grid>
<vsm:VisualStateManager.VisualStateGroups>
<vsm:VisualStateGroup x:Name="CommonStates">
<vsm:VisualState x:Name="Disabled"/>
<vsm:VisualState x:Name="Normal"/>
<vsm:VisualState x:Name="MouseOver"/>
<vsm:VisualState x:Name="Pressed">
<Storyboard>
<ObjectAnimationUsingKeyFrames Storyboard.TargetName="Inner"
Storyboard.TargetProperty="(ScaleTransform.ScaleY)">
<DiscreteObjectKeyFrame KeyTime="0:0:0.0" Value="1"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames Storyboard.TargetName="Outer"
Storyboard.TargetProperty="(ScaleTransform.ScaleY)">
<DiscreteObjectKeyFrame KeyTime="0:0:0.0" Value="-1"/>
</ObjectAnimationUsingKeyFrames>
</Storyboard>
</vsm:VisualState>
</vsm:VisualStateGroup>
<vsm:VisualStateGroup x:Name="FocusStates">
<vsm:VisualState x:Name="Focused"/>
<vsm:VisualState x:Name="Unfocused"/>
</vsm:VisualStateGroup>
</vsm:VisualStateManager.VisualStateGroups>
<Ellipse Margin="2" Fill="{TemplateBinding Background}"
RenderTransformOrigin="0.5,0.5">
<Ellipse.RenderTransform>
<ScaleTransform ScaleY="1" x:Name="Outer"/>
</Ellipse.RenderTransform>
</Ellipse>
<Ellipse Margin="10" Fill="{TemplateBinding Background}"
RenderTransformOrigin="0.5,0.5">
<Ellipse.RenderTransform>
<ScaleTransform ScaleY="-1" x:Name="Inner"/>
</Ellipse.RenderTransform>
</Ellipse>
<ContentPresenter x:Name="content" HorizontalAlignment="Center" VerticalAlignment="Center"/>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</UserControl.Resources>
See below:
data:image/s3,"s3://crabby-images/2283d/2283d5d9b30402ae4acf1d62af2c2db0365ffb70" alt="MainPage Resources"
Step 6
Return to the MainPage Designer View by selecting the "MainPage.xaml" Tab.
Then from the All Silverlight Controls section in the Toolbox select the Canvas control:
data:image/s3,"s3://crabby-images/37b94/37b94df837b2679ee56e2e3e3846c03c924f5a30" alt="Canvas Control"
Step 7
Draw a Canvas that fill the whole Page or in the XAML Pane between the "<Grid>" and "</Grid>" lines type the following XAML:
<Canvas Height="300" Width="400" HorizontalAlignment="Left" VerticalAlignment="Top" Name="Page">
</Canvas>
See below:
data:image/s3,"s3://crabby-images/681fc/681fc197d7de78c0cba662f8d01b9d9f85365955" alt="MainPage with Canvas"
Step 8
Then from the Common Silverlight Controls section in the Toolbox select the Button control:
data:image/s3,"s3://crabby-images/64be8/64be82595b376a2e343a212b9b9da94a40f46123" alt="Button Control"
Step 9
Draw a Button on the Page by dragging a Button from the Toolbox onto the Canvas then in the XAML Pane inbetween the "<Canvas>" and "</Canvas>" tags change the "<Button>" line to the following:
<Button Canvas.Left="125" Canvas.Top="75" Height="150" Width="150" Style="{StaticResource CircleButton}" Content="Click Here" Name="HelloWorld"/>
See below:
data:image/s3,"s3://crabby-images/262fb/262fb2b1d1fff2fb1ccc7ba3cbb01e78c953a1ff" alt="Button Control"
Step 10
The Button should have the "CircleButton" Style applied to it.
Then Double Click on the Button Control and type in the HelloWorld_Click Sub:
MessageBox.Show("Hello World")
See Below:
data:image/s3,"s3://crabby-images/4c375/4c3753d768a7313b5abd48182973f52e3e6b17fa" alt="Button Click Event"
Step 11
Save the Project as you have now finished the Silverlight application. Select Debug then Start Debugging or click on Start Debugging:
data:image/s3,"s3://crabby-images/ff3e2/ff3e2dc36fd5826bdfaf1c933648df5ef8494d62" alt="Start Debugging"
After you do, the following will appear in a new Web Browser window:
data:image/s3,"s3://crabby-images/37e86/37e86ed59627f036ecb725933738547a0cfce99e" alt="Application Running"
Step 12
Now click where it says "Click Here" and a Message Box will appear with the following contents:
data:image/s3,"s3://crabby-images/aae1f/aae1f8737ac93eb18d8778d2577ee1172e1e6bc3" alt="Message Box"
Step 13
Close the Application and Browser window by clicking on the Close Button on
the top right of the Application Window and Web Browser to Stop the application.
That was a simple example of Customising the Control Template of a Control such as a Button, it is possible to change the look-and-feel of other controls or add more behavours - there are other states such as MouseOver, Focused and Disabled, see what you can make your control do!