2009-06-30 85 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