Just found a very interesting post by Ayende Rahien on using WCF services asynchronously without generated proxies. And Mark J. Miller in his blog shows how to use the approach in Silverlight application.
пятница, 26 февраля 2010 г.
воскресенье, 14 февраля 2010 г.
Binding to custom attached property
This is a quick post on an interesting binding issue I came across the other day.
In most cases it is possible to omit the name of the Path parameter in the binding markup. But if you binding to a custom attached property, you may encounter a problem. See the code snippet below:
<Window
x:Class="BindingIssueDemo.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:BindingIssueDemo"
Title="MainWindow" Height="350" Width="525">
<DockPanel>
<TextBlock DockPanel.Dock="Top"
Text="{Binding (DockPanel.Dock), RelativeSource={RelativeSource Self}}" />
<TextBlock local:CustomProperties.Description="Custom attached property"
Text="{Binding (local:CustomProperties.Description), RelativeSource={RelativeSource Self}}" />
</DockPanel>
</Window>
System.Windows.Data Error: 39 : BindingExpression path error: '(local:CustomProperties.Description)' property not found on 'object' ''TextBlock' (Name='')'. BindingExpression:Path=(local:CustomProperties.Description); DataItem='TextBlock' (Name=''); target element is 'TextBlock' (Name=''); target property is 'Text' (type 'String')
<TextBlock local:CustomProperties.Description="Custom attached property"
Text="{Binding Path=(local:CustomProperties.Description), RelativeSource={RelativeSource Self}}" />
воскресенье, 7 февраля 2010 г.
DXPrinting: using DataTemplateSelector with SimpleLink
Printing data with a SimpleLink is straightforward: define a DataTemplate that represents a data item layout, specify the number of items and call the CreateDocument method.
But what if your data consists of objects of different types? How do you print them when each type has its own layout? This is where DataTemplateSelector comes to help.
Consider that we have a collection of CalendarEntry objects:
Let's start with creating a DataTemplate for each calendar entry type. To keep things simple, I'm using a very simple layout:
<DataTemplate x:Key="anniversary">
<Border BorderBrush="Black" BorderThickness="1" CornerRadius="5" Margin="0,0,0,5" Background="LightBlue">
<StackPanel Margin="5">
<TextBlock Text="{Binding Date, StringFormat='Date: {0}'}" />
<TextBlock Text="{Binding Occasion, StringFormat='Occasion: {0}'}" />
</StackPanel>
</Border>
</DataTemplate>
<DataTemplate x:Key="todo">
<Border BorderBrush="Black" BorderThickness="1" CornerRadius="0" Margin="0,0,0,5" Background="LightGray">
<StackPanel Margin="5">
<TextBlock Text="{Binding DueDate, StringFormat='Due Date: {0}'}" />
<TextBlock Text="{Binding Subject, StringFormat='Subject: {0}'}" />
</StackPanel>
</Border>
</DataTemplate>
<DataTemplate x:Key="meeting">
<Border BorderBrush="Black" BorderThickness="1" CornerRadius="0" Margin="0,0,0,5" Background="LightGreen">
<StackPanel Margin="5">
<TextBlock Text="{Binding Subject, StringFormat='Subject: {0}'}" />
<TextBlock Text="{Binding Location, StringFormat='Location: {0}'}" />
<TextBlock Text="{Binding Start, StringFormat='Start: {0}'}" />
<TextBlock Text="{Binding End, StringFormat='End: {0}'}" />
</StackPanel>
</Border>
</DataTemplate>
Now when we have our data templates, let's create a data template selector. Instead of writing an ad-hoc selector simply for this example, I've built a reusable DetailTemplateSelector class. It provides the Type and DataTemplate properties, which allows you to configure it as follows:
<local:DetailTemplateSelector x:Key="calendarEntryTemplateSelector">
<local:DetailTemplateSelector.Templates>
<DataTemplate x:Key="{x:Type local:ToDoNote}">
<!-- ToDoNote template definition -->
</DataTemplate>
<DataTemplate x:Key="{x:Type local:Anniversary}">
<!-- Anniversary template definition -->
</DataTemplate>
<DataTemplate x:Key="{x:Type local:Meeting}">
<!-- Meeting template definition -->
</DataTemplate>
</local:DetailTemplateSelector.Templates>
</local:DetailTemplateSelector>
And now the final trick: the SimpleLink class doesn't have any property to set a data template selector. We use a workaround: our detail template is a ContentPresenter and its ContentTemplateSelector property is set to the DetailTemplateSelector object:
<DataTemplate x:Key="calendarEntry">
<ContentPresenter ContentTemplateSelector="{StaticResource calendarEntryTemplateSelector}" />
</DataTemplate>
Now we can use a link to build a document and show its print preview:
Easy enough, isn’t it?
Random thoughts, ideas and questions on .NET development