Simple Template Definition in Silverlight PRO

Templates allow us to apply a set of design rules on the controls we have on our page. They change the visual face of every common control. Unlike styles, when using a template we are not limited for those properties that were defined in the Element class. Templates are limited for those elements that extend the Control class. We cannot use them on others. Every control has a built-in recipe that determines how it should be rendered. This recipe is known as the control template. The template is defined using XAML and is applied using the Template property.

<UserControl x:Class="SilverlightApplication28.MainPage"
    xmlns="http://schemas.microsoft.com/client/2007" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    Width="400" Height="300">
    <UserControl.Resources>
        <Color x:Key="MyBackgroundColor">#CCCCCCCC</Color>
        <ControlTemplate x:Key="MyButtonTemplate" TargetType="Button">
            <Border BorderBrush="Red" BorderThickness="4" 
                    CornerRadius="12" Background="{TemplateBinding Background}">
                <ContentPresenter>
                </ContentPresenter>
            </Border>
        </ControlTemplate>
        <Style x:Key="MyButtonStyle" TargetType="Button">
            <Setter Property="Foreground" 
                    Value="Blue"></Setter>
            <Setter Property="Background" 
                    Value="{StaticResource MyBackgroundColor}"></Setter>
            <Setter Property="Template" 
                    Value="{StaticResource MyButtonTemplate}"></Setter>
        </Style>
    </UserControl.Resources>
    <StackPanel x:Name="ApplicationLayout" Background="LightYellow" >
        <Button Style="{StaticResource MyButtonStyle}" 
                Content="Simple Templated Button" 
                Margin="10" Padding="20" FontSize="22">            
        </Button>
    </StackPanel>
</UserControl>

The following video clip goes over this code sample, explains it and shows its output.

Share:

The Visitor Design Pattern

The Visitor Design Pattern

The visitor design pattern allows us to add operations to objects that already exist without modifying their classes and without extending them.

What are Anti Patterns?

Anti Patterns

Unlike design patterns, anti patterns just seem to be a solution. However, they are not a solution and they cause additional costs.

Virtual Threads in Java Professional Seminar

Virtual Threads in Java

The use of virtual threads can assist us with improving the performance of our code. Learn how to use virtual threads effectively.

NoSQL Databases Courses, Seminars, Consulting, and Development

MongoDB Design Patterns Meetup

The use of MongoDB involves with various cases in which we can overcome performance issues by implementing specific design patterns.

image of woman and database

Record Classes in Java

Learn how to define record classes in Java, and when to use record classes in your code. Stay up to date with the new Java features.

Accessibility | Career | Conferences | Design Patterns | JavaScript | Meetups | PHP | Podcasts | Python | Self Learning

Teaching Methodologies | Fullstack | C++ | C# | CSS | Node.js | Angular | Java | Go | Android | Kotlin | Swift | Academy

Front End Development | Scala | Architectures | Cloud | Big Data | Internet of Things | Kids Learn Programming

The Beauty of Code

Coding is Art! Developing Code That Works is Simple. Develop Code with Style is a Challenge!

Skip to content Update cookies preferences