Wahlin on .NET

Getting Started with Silverlight 2 Controls

Don't worry, ASP.NET developers: Siverlight 2 controls aren't so different from what you're used to, as Dan shows.

Silverlight 2 provides a variety of controls that can be used to collect and display data, display collections of items, and play media. Developers coming from ASP.NET will find that using Silverlight controls is similar in many ways to using ASP.NET server controls because the Silverlight controls can be defined using an XML syntax and expose properties, methods and events.

While Visual Studio 2008 doesn't currently allow Silverlight controls to be dragged and dropped onto the design surface, controls can be dragged from the toolbox and dropped into XAML files. For those looking for a more visual design experience, Microsoft's Expression Blend 2.5 allows Silverlight controls to be dragged from a toolbox directly onto the design surface. Developers accustomed to typing controls directly in code can do so directly in the XAML code editor, as well.

What Controls Are Available?
Silverlight 2 provides controls that perform basic tasks (such as collecting data) to more advanced tasks (such as playing media files and arranging items). Controls can be classified into four main categories: user input controls, layout controls, items controls and media controls.

Figure 1 shows the different Silverlight 2 controls in the toolbox (the controls shown were available as of Silverlight 2 beta 2).

User input controls include common controls found in many other frameworks -- such as TextBox, Button and CheckBox -- as well as some non-standard controls such as RepeatButton. Layout controls include controls such as Canvas, Grid and StackPanel, and items controls (used to show collections of items) include controls such as DataGrid and ListBox. Finally, media controls include MediaElement, Image and MultiScaleImage.

Using Silverlight Controls
Whether you type the controls directly into the code editor or drag them from the toolbox, you'll quickly learn that XAML isn't quite as forgiving as HTML and ASP.NET. XAML follows the rules defined in the XML specification, which means that tags have to be properly cased and closed and attributes must be quoted.

An example of defining a Silverlight TextBox control in a XAML file is shown below. Note that all of the tags defined in the XAML code have closing tags (or rely on shortcut closing tag syntax) and that all of the attribute values are quoted:

<UserControl x:Class="SilverlightApplication1.Page"
    xmlns="http://schemas.microsoft.com/client/2007" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    Width="400" Height="300">
    <Grid x:Name="LayoutRoot" Background="White">
        <TextBlock Text="Name" Margin="10" />
        <TextBox x:Name="txtName" Width="100" />
    </Grid>
</UserControl>

Looking through this XAML code, you'll notice that a Name attribute is used instead of the ID attribute found on ASP.NET controls. The x in front of the Name attribute represents an XML namespace prefix defined on the root UserControl element of the XAML file. Although you'll see x:Name used in many examples, Silverlight also allows the Name attribute (without the x namespace prefix) to be used.

Silverlight controls expose events just like ASP.NET server controls that can be handled by an event handler. For example, the Silverlight Button control exposes a Click event that can be handled using different languages such as C# or VB.NET. Here is an example of defining a Button control:

<Button x:Name="btnSubmit" Content="Go" 
    Click="btnSubmit_Click" />

The Button control's Click event is wired to an event handler named btnSubmit_Click by using the Click attribute -- similar to using the ASP.NET Button control's OnClick attribute in an ASPX file. When the event fires the following code is called:

private void btnSubmit_Click
    (object sender, RoutedEventArgs e)
{
    //Handle event 
}

You may wonder why Silverlight substitutes EventArgs for RoutedEventArgs. Silverlight relies on control trees behind the scenes to organize and manage parent and child controls. A root control acts as the start of the tree and child controls are nested under it. The root control's children can also have children of their own, which ultimately creates an object hierarchy or control tree.

The process of notifying a parent of an action that occurred on a child is referred to as a "routed event" because mouse or keyboard events triggered by a control are "routed" up the tree so a parent can be notified when an event occurs. Routed events are similar to event bubbling found in other languages.

I've only scratched the surface of Silverlight controls and introduced you to some of the fundamental concepts in this article. In future articles, I'll provide additional details about the controls and show how they can be used to build Silverlight applications.

About the Author

Dan Wahlin (Microsoft MVP for ASP.NET and XML Web Services) is the founder of The Wahlin Group which specializes in .NET and SharePoint onsite, online and video training and consulting solutions. Dan also founded the XML for ASP.NET Developers Web site, which focuses on using ASP.NET, XML, AJAX, Silverlight and Web Services in Microsoft's .NET platform. He's also on the INETA Speaker's Bureau and speaks at conferences and user groups around the world. Dan has written several books on .NET including "Professional Silverlight 2 for ASP.NET Developers," "Professional ASP.NET 3.5 AJAX, ASP.NET 2.0 MVP Hacks and Tips," and "XML for ASP.NET Developers." Read Dan's blog here.

comments powered by Disqus

Featured

  • Compare New GitHub Copilot Free Plan for Visual Studio/VS Code to Paid Plans

    The free plan restricts the number of completions, chat requests and access to AI models, being suitable for occasional users and small projects.

  • Diving Deep into .NET MAUI

    Ever since someone figured out that fiddling bits results in source code, developers have sought one codebase for all types of apps on all platforms, with Microsoft's latest attempt to further that effort being .NET MAUI.

  • Copilot AI Boosts Abound in New VS Code v1.96

    Microsoft improved on its new "Copilot Edit" functionality in the latest release of Visual Studio Code, v1.96, its open-source based code editor that has become the most popular in the world according to many surveys.

  • AdaBoost Regression Using C#

    Dr. James McCaffrey from Microsoft Research presents a complete end-to-end demonstration of the AdaBoost.R2 algorithm for regression problems (where the goal is to predict a single numeric value). The implementation follows the original source research paper closely, so you can use it as a guide for customization for specific scenarios.

  • Versioning and Documenting ASP.NET Core Services

    Building an API with ASP.NET Core is only half the job. If your API is going to live more than one release cycle, you're going to need to version it. If you have other people building clients for it, you're going to need to document it.

Subscribe on YouTube