2009-06-30 2 views
1

Я создал Treeview и использовал панель стека, чтобы включить флажок, изображение значка и текст для каждого узла в дереве. Эти узлы создаются во время выполнения. У меня также есть объект кнопки. Xaml внизу.WPF Treeview - Получить статус флажка

Проблема заключается в том, что при нажатии кнопки click me, мне нужно пройти через древовидное представление, и если флажок установлен, выполните некоторую функцию.

Кто-нибудь знает, как узнать, установлен ли флажок для узла в дереве, из кода 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? –

+0

TreeViewItems. Это ответ? Если нет, сообщите мне, какая вам другая информация. – trainer

ответ

7

Я хотел бы создать данные двухстороннюю связывания с этим Check IsChecked окно свойств для объекта ViewModel вместо этого. Гораздо проще, чем перемещаться по дереву.


Редактировать (по желанию лица с просьбой):

Вот пример View Model (очень простое, что только учет для 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. Поэтому вы должны обновить свойство IsChecked вашего CheckBox к этому свойству. Для этого вам сначала нужно установить DataContext Window1 каким-либо образом (или вы можете просто сделать это на самом TreeView). В вашем Window1.xaml.cs:

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

Затем в файле Window1.xaml, обновите свойство CheckBox IsChecked:

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

, а затем в любом коде, вы должны быть в состоянии опрашивать в настоящее время стоимость IsChecked, вы можете добраться до него таким образом (предполагается, что этот является Window1):

((ViewModel)this.DataContext).IsChecked 

Надежда, что помогает!

1

Я думаю, что ответ Тони Хеупеля - лучший подход, но чтобы понять его, вам нужно знать о шаблоне проектирования MVVM (Model-View-ViewModel). Я предлагаю вам прочитать это excellent article by Josh Smith

Смежные вопросы