昨天的文章里写了将TreeView里的CheckBox和TreeViewItem关联起来。但是功能太单一,今天稍微改了一下,加了点功能,显得更好看,可以在点击每个节点的时候改变其父节点及子节点的勾选状态,更符合平时的习惯。这是学习XAML以来做的第一个小程序,所以一定要记录一下。
现在我们需要的效果是这样的:选中一个节点以后,所有子节点选中,取消一个节点选中以后,所有子节点也取消选中;改变一个节点状态,如果其父节点的所有子节点都勾选了,则其父节点选中,如果全部没勾选,则父节点取消选中,否则,其父节点的CheckBox为null,同理再往上一层找父节点的父节点
首先,XAML如下
<Window.Resources>
<Style TargetType="TreeViewItem">
<Setter Property="IsExpanded" Value="True" />
</Style>
</Window.Resources>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<TreeView Name="TVCountry" Margin="3">
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemsSource="{Binding Children}">
<StackPanel Orientation="Horizontal">
<CheckBox Name="chkbox" Click="chkbox_Click" IsChecked="{Binding IsSelected}"