I was able to get it work!
1) First treaky thing : You must find where HierarchicalDataTemplate is living
xmlns:xctrl="clr-namespace:System.Windows;assembly=System.Windows.Controls"
2) In silverlight you should explicitly point thе template. While in WPF the way you move is type recognition in hierarhy. There is DataType property for HierarchicalDataTemplate in WPF.
Here in silverlight ItemTemplate for ChildTemplate. For child use DataTemplate or HierarhicalDataTemplate
<UserControl x:Class="TestSilverlight5.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:xctrl="clr-namespace:System.Windows;assembly=System.Windows.Controls"
mc:Ignorable="d"
d:DesignHeight="337" d:DesignWidth="591" xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk" xmlns:data="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data" xmlns:controls="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls" Loaded="UserControl_Loaded">
<Grid x:Name="LayoutRoot" Background="White">
<Grid.Resources>
<xctrl:HierarchicalDataTemplate x:Key="ChildTemplate">
<CheckBox Content="{Binding Path=Name}" IsChecked="{Binding Path=IsSelected, Mode=TwoWay}"></CheckBox>
</xctrl:HierarchicalDataTemplate>
<xctrl:HierarchicalDataTemplate x:Key="ParentTemplate" ItemsSource="{Binding Path=Users, Mode=TwoWay}" ItemTemplate="{StaticResource ChildTemplate}">
<CheckBox FontStyle="Italic" Content="{Binding Path=Name}" IsChecked="{Binding Path=IsSelected, Mode=TwoWay}"></CheckBox>
</xctrl:HierarchicalDataTemplate>
</Grid.Resources>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="200" />
<ColumnDefinition Width="12" />
<ColumnDefinition Width="1*" />
</Grid.ColumnDefinitions>
<data:DataGrid AutoGenerateColumns="False" Name="dataGrid1" Grid.Column="2">
<data:DataGrid.Columns>
<data:DataGridCheckBoxColumn CanUserReorder="True" CanUserResize="True" CanUserSort="True" Width="Auto" />
<data:DataGridCheckBoxColumn CanUserReorder="True" CanUserResize="True" CanUserSort="True" Width="Auto" />
<data:DataGridCheckBoxColumn CanUserReorder="True" CanUserResize="True" CanUserSort="True" Width="Auto" />
<data:DataGridCheckBoxColumn CanUserReorder="True" CanUserResize="True" CanUserSort="True" Width="Auto" />
<data:DataGridCheckBoxColumn CanUserReorder="True" CanUserResize="True" CanUserSort="True" Width="Auto" />
</data:DataGrid.Columns>
</data:DataGrid>
<controls:GridSplitter Grid.Column="1" HorizontalAlignment="Stretch" Grid.Row="0" Name="gridSplitter1" Width="12" Cursor="SizeWE">
<controls:GridSplitter.Background>
<LinearGradientBrush EndPoint="1,0.5" StartPoint="0,0.5">
<GradientStop Color="#FFBCF1F1" Offset="0" />
<GradientStop Color="#FFC8CDCD" Offset="1" />
<GradientStop Color="#FFEBFBFB" Offset="0.325" />
<GradientStop Color="#FFA3B3B3" Offset="0.797" />
</LinearGradientBrush>
</controls:GridSplitter.Background>
</controls:GridSplitter>
<Button Content="View" HorizontalAlignment="Left" Margin="7,0,0,5" Name="buttonView" Width="65" Height="23" VerticalAlignment="Bottom" />
<controls:TreeView Name="treeView" ItemTemplate="{StaticResource ParentTemplate}">
</controls:TreeView>
</Grid>
</UserControl>
Комментариев нет:
Отправить комментарий