Control Templates enable the look-and-feel of Controls on Windows Phone 7 to differ allowing for a flexible user experience beyond the standard, such as customising a Button look and behaviour using Visual State Manager.
Printer Friendly Download Tutorial (444KB) Download Source Code (16.4KB)
Step 1
Start Microsoft Visual Studio 2010 Express for Windows Phone, then Select File then New Project... Select "Visual C#" then "Silverlight for Windows Phone" and then "Windows Phone 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/95085/95085e993da40f088b13a8adf0f04e701c04a613" alt="New Project"
Step 2
A Windows Phone application Page named MainPage.xaml should then appear, see below:
data:image/s3,"s3://crabby-images/15c4f/15c4fd97c601ea6b6903dec1a7a2a0c73c5e96d2" alt="MainPage.xaml"
Step 3
Then in the XAML Pane for MainPage.xaml, below the x:Class="ControlTemplate.MainPage" entry, type the following XAML namespace:
xmlns:vsm="clr-namespace:System.Windows;assembly=System.Windows"
See below:
data:image/s3,"s3://crabby-images/a03b5/a03b5d068296eeff43398723644ef3023ecec0c1" alt="MainPage Namespace"
Step 4
While still in the XAML Pane above the <Grid x:Name="LayoutRoot" Background="Transparent"> line type the following XAML:
<phone:PhoneApplicationPage.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="4" Fill="{TemplateBinding Background}"
RenderTransformOrigin="0.5,0.5">
<Ellipse.RenderTransform>
<ScaleTransform ScaleY="1" x:Name="Outer"/>
</Ellipse.RenderTransform>
</Ellipse>
<Ellipse Margin="20" 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>
</phone:PhoneApplicationPage.Resources>
See below:
data:image/s3,"s3://crabby-images/69655/69655807ad52cd5530909463362754af9c74d488" alt="ControlTemplate Style Resource XAML"
Step 5
Return to the MainPage.xaml Designer View by selecting the "MainPage.xaml" Tab
Then from the Windows Phone Controls section in the Toolbox select the Button control:
data:image/s3,"s3://crabby-images/76202/76202eccbbae3cce5fd6c310a91ea4dc4df80c6e" alt="Button Control"
Step 6
Draw a Button on the Page by dragging the Button from the Toolbox onto the Page, then in the XAML Pane between the <Grid x:Name="ContentGrid" Grid.Row="1"> and </Grid> lines, change the "Button1" line to the following:
<Button Height="250" Width="250" Style="{StaticResource CircleButton}" Content="Tap Here" Name="HelloWorld"/>
See below:
data:image/s3,"s3://crabby-images/e225d/e225da3b9e8cbf5901b1eb138a3062f5c11495ed" alt="MainPage with Button"
Step 7
The Button should have the "CircleButton" Style applied and not appear as a standard Button on Windows Phone 7.
Double Click on the Button Control and type in the HelloWorld_Click method:
PageTitle.Text = "Hello World";
See Below:
data:image/s3,"s3://crabby-images/2dee2/2dee21a1d28793811d2738c300d5180436df5cd8" alt="Button Click Event"
Step 8
Save the Project as you have now finished the Windows Phone Silverlight application. Select the Windows Phone Emulator option then Select Debug then Start Debugging or click on Start Debugging:
data:image/s3,"s3://crabby-images/216ae/216ae12d45227d046f30e709372a559cf3e92e99" alt="Start Debugging"
After you do, the following will appear in the Windows Phone Emulator after it has been loaded:
data:image/s3,"s3://crabby-images/3a524/3a5247a9e5b264dedaef46cc6161871f11b265c7" alt="Application Running"
Step 9
Now tap where it says "Tap Here" and the page title will change to Hello World, see below:
data:image/s3,"s3://crabby-images/ea363/ea363532dbf5539106c5fd1a782f64b1b7917498" alt="Control Template"
Step 10
You can then Stop the application by selecting the Visual Studio 2010 application window and clicking on the Stop Debugging button:
data:image/s3,"s3://crabby-images/4ada7/4ada7ca65feda9cee86d40589952e0ade14177d5" alt="Stop Debugging"
This is a simple example of how to Customise 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 behaviours - make it your own!