コードを読むのは非常に難しいと思いますが、私はベストを尽くそうとします!ここでTreeViewの親ノードへのアクセス?
は私のXAMLコードがある:ときに私、今
:
<TreeView x:Name="stateMachinesView"
DockPanel.Dock="Top"
SelectedItemChanged="item_Selected"
HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"
ScrollViewer.HorizontalScrollBarVisibility="Disabled"
BorderThickness="0">
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemsSource="{Binding Value}">
<HierarchicalDataTemplate.ItemTemplate>
<DataTemplate>
<DockPanel>
<DockPanel.ContextMenu>
<ContextMenu>
<MenuItem Header="Create Thumbnail"
Click="MenuItemCreate_Click"/>
</ContextMenu>
</DockPanel.ContextMenu>
<Image>
<Image.Style>
<Style TargetType="Image">
<Style.Setters>
<Setter Property="Source"
Value="Resources\state.png"/>
</Style.Setters>
<Style.Triggers>
<DataTrigger Binding="{Binding Item2}"
Value="true">
<Setter Property="Source"
Value="Resources\state_init.png"/>
</DataTrigger>
</Style.Triggers>
</Style>
</Image.Style>
</Image>
<TextBlock>
<TextBlock.Text>
<Binding Path="Item1"/>
</TextBlock.Text>
</TextBlock>
</DockPanel>
</DataTemplate>
</HierarchicalDataTemplate.ItemTemplate>
<DockPanel>
<Image DockPanel.Dock="Left"
Source="Resources\state_machine.png"/>
<TextBlock Text="{Binding Key}"/>
</DockPanel>
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
この項目ソースがDictionary<string, ObservableCollection<Tuple<string, bool>>>
視覚的にですが、私はこのような何かを得ました私のMenuItem
をクリックしてください:
private void MenuItemCreate_Click(object sender, RoutedEventArgs e)
{
string stateName =
((sender as FrameworkElement).DataContext as Tuple<string, bool>).Item1;
}
私は上記のコードでState1_1にアクセスすることができますが、今、私はSM1親ノードにアクセスしたいと思います!
DependencyObject parent = VisualTreeHelper.GetParent(sender as DependencyObject);
while (!(parent is TreeViewItem))
parent = VisualTreeHelper.GetParent(parent);
しかし、それは、私は、あまりにも、テンプレート考えています
...動作しません:私は多くのことを試してみました
、(解決に)最も近いが、このでしたXAMLで、私は簡単にコードビハインドでそれを行うことができます!
あなたはTreeview ..を介してループする簡単な方法をお探しですか?その場合は、コード内のスターターとして使用できる非常に簡単な例を貼り付けることができます。 – MethodMan