Here is a small example of the DataTemplate
. There is a Grid
in which there are Expander
with two TextBlocks
. One is inside the expander InnerTextBlock
, and the other one is not in - OuterTextBlock
. When a property IsExpanded
== True
we do specific operations with DataTriggers
.
XAML
<Window.Resources>
<DataTemplate DataType="{x:Type local:MyExpanderData}">
<Grid x:Name="MainGrid">
<Expander Name="MyExpander" Header="{Binding HeaderName}" IsExpanded="{Binding isExpanded}">
<TextBlock Name="InnerTextBlock" Text="InnerTextBlock" Width="150" Height="30" VerticalAlignment="Top" FontSize="16" />
</Expander>
<TextBlock Name="OuterTextBlock" Text="OuterTextBlock" Width="150" Height="30" Margin="0,30,0,0" FontSize="16" />
</Grid>
<!-- Our DataTriggers -->
<DataTemplate.Triggers>
<DataTrigger Binding="{Binding ElementName=MyExpander, Path=IsExpanded}" Value="True">
<Setter TargetName="OuterTextBlock" Property="Opacity" Value="0.5" />
</DataTrigger>
<DataTrigger Binding="{Binding ElementName=MyExpander, Path=IsExpanded}" Value="True">
<Setter TargetName="InnerTextBlock" Property="Foreground" Value="Red" />
</DataTrigger>
<DataTrigger Binding="{Binding ElementName=MyExpander, Path=IsExpanded}" Value="True">
<Setter TargetName="MyExpander" Property="Header" Value="Expander open" />
</DataTrigger>
</DataTemplate.Triggers>
</DataTemplate>
<!-- Resource data for the Expander -->
<local:MyExpanderData x:Key="MyExpanderData" HeaderName="Test Expander" isExpanded="True" />
</Window.Resources>
<Grid>
<!-- Our DataTemplate in ContentControl -->
<ContentControl Name="MyContentControl" Content="{StaticResource MyExpanderData}" />
</Grid>
Code behind
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
}
public class MyExpanderData
{
private bool expanded = false;
private string headerName = "";
public bool isExpanded
{
get
{
return expanded;
}
set
{
expanded = value;
}
}
public string HeaderName
{
get
{
return headerName;
}
set
{
headerName = value;
}
}
}
In the class MyExpanderData
stored data, which are then Binding
in our DataTemplate
. All properties are stored in a DataTemplate
, we can set via this class.