2009-06-30 99 views
1

我创建了一个Treeview并使用堆栈面板为树中的每个节点添加了复选框,图标图像和文本。 这些节点是在运行时创建的。 我也有一个按钮对象。 xaml在下面。WPF Treeview - 获取复选框的状态

我遇到的问题是,当点击我点击按钮时,我需要遍历树视图,如果复选框被选中,执行一些功能。

有谁知道如何检查树中的节点复选框是否被选中,从后面的C#代码?

<Window x:Class="WPF_Explorer_Tree.Window1" 
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
xmlns:local="clr-namespace:WPF_Explorer_Tree" 
Title="KryptoG" Height="424" Width="815" Loaded="Window_Loaded"> 
<Window.Resources> 
    <local:HeaderConverter x:Key="formatter" /> 
</Window.Resources> 
<Grid> 
    <TreeView x:Name="foldersItem" SelectedItemChanged="foldersItem_SelectedItemChanged" Background="#FFFFFFFF" BorderBrush="#FFFFFFFF" Foreground="#FFFFFFFF" Margin="0,0,236,112" AllowDrop="True" Visibility="Visible"> 
     <TreeView.Resources> 
      <Style TargetType="{x:Type TreeViewItem}"> 
       <Setter Property="HeaderTemplate"> 
        <Setter.Value> 
         <DataTemplate> 
          <StackPanel Name="ST" Orientation="Horizontal"> 
           <CheckBox VerticalAlignment="Center" Name="SelectedCheckBox" IsChecked="False" Checked="CheckBox_Checked" Unchecked="CheckBox_Unchecked" /> 
          <Image Name="img" Width="20" Stretch="Fill" 
            Source="{Binding 
            RelativeSource={RelativeSource 
            Mode=FindAncestor, 
            AncestorType={x:Type TreeViewItem}}, 
            Path=Header, 
            Converter={x:Static local:HeaderToImageConverter.InstanceIcon}}"  
            /> 
           <TextBlock VerticalAlignment="Center" Text="{Binding 
            RelativeSource={RelativeSource 
            Mode=FindAncestor, 
            AncestorType={x:Type TreeViewItem}}, 
            Path=Header, 
            Converter={StaticResource formatter}}" 
            /> 
          </StackPanel> 
         </DataTemplate> 
        </Setter.Value> 
       </Setter> 
      </Style> 
     </TreeView.Resources> 
    </TreeView> 
    <TreeView HorizontalAlignment="Right" Margin="0,0,12,12" Name="treeView1" Width="204" AllowDrop="True" BorderBrush="White" Foreground="White" /> 
    <Button Height="23" HorizontalAlignment="Left" Margin="12,0,0,70" Name="button1" VerticalAlignment="Bottom" Width="75" Click="button1_Click">Click Me</Button> 
    <Button Height="23" HorizontalAlignment="Left" Margin="267,0,0,69" Name="button2" VerticalAlignment="Bottom" Width="75" Click="button2_Click">Click Me too</Button> 
</Grid> 

+0

你把什么东西放到你的TreeView中? – 2009-06-30 21:00:18

回答

7

我将建立一个双向数据,而不是与复选框的财产器isChecked绑定到一个ViewModel对象。比导航树要容易得多。


编辑(每个人的请求,要求):

下面是一个例子视图模型(非常简单,其仅约占器isChecked属性):

public class ViewModel : System.ComponentModel.INotifyPropertyChanged 
{ 
    private bool? _isChecekd; 
    public bool? IsChecked 
    { 
     get { return _isChecekd; } 
     set 
     { 
      if (_isChecekd != value) 
      { 
       _isChecekd = value; 
       if (PropertyChanged != null) 
       { 
        PropertyChanged(this, new System.ComponentModel.PropertyChangedEventArgs("IsChecked")); 
       } 
      } 
     } 
    } 
    #region INotifyPropertyChanged Members 
    public event System.ComponentModel.PropertyChangedEventHandler PropertyChanged; 
    #endregion 
} 

现在你有一个实现INotifyPropertyChanged的对象,您可以将UI元素属性绑定到它们。因此,您需要将CheckBox的IsChecked属性更新为此属性。要做到这一点,您首先必须以某种方式设置Window1的DataContext(或者您也可以在TreeView本身上执行此操作)。在您的Window1.xaml.cs:

public Window1() 
     { 
      InitializeComponent(); 
      this.DataContext = new ViewModel(); 
     } 

然后,在你的Window1.xaml文件,更新复选框财产器isChecked:

<CheckBox VerticalAlignment="Center" Name="SelectedCheckBox" IsChecked="{Binding Path=IsChecked, Mode=TwoWay}" Checked="CheckBox_Checked" Unchecked="CheckBox_Unchecked" /> 

,然后在任何代码,你需要能够询问的器isChecked当前值,就可以得到它这样(假设是窗口1):

((ViewModel)this.DataContext).IsChecked 

希望帮助!

1

我认为Tony Heupel的答案是最好的方法,但要了解它,您需要了解MVVM(Model-View-ViewModel)设计模式。我建议你看看这个excellent article by Josh Smith