Prologue:
We know that Silverlight 5 has new features. Among the features the most demanding feature is debugging the Data Bindings in XAML. In this article we shall see the most demanding feature of Silverlight 5 Beta.
Short notes on Debugging Data Bindings in XAML:
If you bind data to controls in XAML, you can't see whether the data is bound or not. You can check the bindings using a custom debugger value converter to see the bound value with the control.
To avoid these things, the Silverlight 5 Beta provides the demanding feature Debugging Data Bindings in XAML. We can test that Debugging Data Bindings in XAML feature of Silverlight 5 Beta in the following way by creating a demo project.
Preparing the Solution:
Fire up Visual Studio 2010; create a Silverlight Project with the name "DebuggingBindingsInXAML".
data:image/s3,"s3://crabby-images/141b3/141b39bedce76a3fb3e497e95fd3818998437136" alt="DebBidSilver1.gif"
Follow the No: #.
Make sure we are creating a Silverlight 5 Application.
data:image/s3,"s3://crabby-images/9f934/9f934de9e439c98769fb99b5bb948483f6b11086" alt="DebBidSilver2.gif"
Designing the UI:
We are going to create a simple screen with a list box. The complete XAML is given below.
data:image/s3,"s3://crabby-images/0d07d/0d07da19152dc00da83d6ab02d84fc12bf25876d" alt="DebBidSilver3.gif"
Place a list box and set the necessary properties.
The Code-Behind:
We have just created the UI part of our application. We need to do something in Code-Behind right?
data:image/s3,"s3://crabby-images/4fcd1/4fcd1c745630bbbc474f33c6536930e386bbd3ef" alt="DebBidSilver4.gif"
Create a property "Names" of type String.
data:image/s3,"s3://crabby-images/b8080/b8080784a99904bcb932859a299e50e8f8fbe4a1" alt="DebBidSilver5.gif"
Assign the Names property with the string collection. Here we are assigning the collection of names in the LoadNames () method.
data:image/s3,"s3://crabby-images/6f908/6f908f4423ac03906f00946f6479c70e2f938b36" alt="DebBidSilver6.gif"
Make sure that the DataContext is set to the LixtBox. As the Names property is in the MainPage.xaml.cs we are assigning the "this" to the list box DataContext.
Break-point on XAML binding:
Now the designing and binding the DataContext has been done. Go to the MainPage.xaml and put a Breakpoint on the Binding line.
data:image/s3,"s3://crabby-images/80d48/80d483f74d70ef4364e41d9382addb16b6c31d42" alt="DebBidSilver7.gif"
Here we have bound the Names property from the MainPage.xaml.cs [this].
Quick Note:
The Break-point will be only on the line which should have the Binding word.
data:image/s3,"s3://crabby-images/c08c0/c08c0d343229c71938a169c2b26d054d3eac39a8" alt="DebBidSilver8.gif"
For example,
if you are trying to put a breakpoint on the height property that does not have a binding, then you could not.
The status bar message will say that "This is not a valid location for a breakpoint".
Now we are nearly finished with the Demo. Press the play button [F5].
When the Page is loaded, the debugger will hit on the Binding as the figure given below.
data:image/s3,"s3://crabby-images/ed9d5/ed9d5cdb22000d8a90789d974796b1cfa9a6b2fb" alt="DebBidSilver9.gif"
To see what's happening while binding the Data with the control, make the Local and Call Stack windows visible.
data:image/s3,"s3://crabby-images/bbf1c/bbf1c00f8d9fcaea2dea4cd5ab65503901bd3296" alt="DebBidSilver10.gif"
These windows will be shown only at run time.
Let us see in the Local window.
data:image/s3,"s3://crabby-images/a34dd/a34dd876cd014e0ad883dd83612555d92371c653" alt="DebBidSilver11.gif"
To see the bound data in the Local Window, explore the BindingState then FinalSource.
In the FinalSource property you can see the bound property names with 6 values.
data:image/s3,"s3://crabby-images/b490f/b490fcdbd85bb0af9e6e810304087a0de5b9142d" alt="DebBidSilver12.gif"
In the Call Stack window, you can see the line number which says the Binding has been done.
So this is how we can debug the XAML bindings in Silverlight.
Summary:
In this article, we have seen the on demand feature called Debugging Data Bindings in XAML in Silverlight 5 Beta.
Thanks for spending your precious time here. Please provide your valuable feedbacks and comments, which enable me to give a better article the next time.
Thanks.