TreeViewのHierarchicalDataTemplate
はGridSplitter
とうまく動作していないようです。実際の問題がどこにあるのか正確にはわかりませんが、私はScrollViewer
と疑っています。HierarchicalDataTemplateとGridSplitter
現在の動作: TreeViewはその項目に従ってのみ適応します。幅の広い項目が展開されると、TreeViewが大きくなります。グリッドスプリッタで縮小または拡大することはできません。 HorizontalAlignment = StretchとScrollViewerのプロパティはこれに影響しないようです。
予想される動作: TreeViewは、GridSplitterの幅を調整し、小さすぎると水平スクロールバーを表示します。
スクリーンショットのように、TreeViewはアイテムの最小幅にとどまり、GridSplitterにアライメントされません。
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" MinWidth="250" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<TreeView Name="treMain" BorderThickness="0" ItemsSource="{Binding TreeViewSections}" ScrollViewer.HorizontalScrollBarVisibility="Visible">
<TreeView.Resources>
<HierarchicalDataTemplate DataType="{x:Type local:TreeViewEntry}" ItemsSource="{Binding Items}">
<StackPanel Orientation="Horizontal" Margin="5,3">
<Image Margin="0,0,5,0">
<Image.Style>
<Style TargetType="Image">
<Setter Property="Source" Value="{Binding Icon}" />
<Style.Triggers>
<DataTrigger Binding="{Binding RelativeSource={RelativeSource AncestorType=TreeViewItem}, Path=IsExpanded}" Value="True">
<Setter Property="Source" Value="{qc:Binding '$P.ExpandedIcon == null || $P.Items.Count == 0 ? $P.Icon : $P.ExpandedIcon', P={Binding}}" />
</DataTrigger>
</Style.Triggers>
</Style>
</Image.Style>
</Image>
<TextBlock Text="{Binding Text}" />
</StackPanel>
</HierarchicalDataTemplate>
</TreeView.Resources>
<TreeView.ItemContainerStyle>
<Style TargetType="{x:Type TreeViewItem}">
<Setter Property="IsExpanded" Value="{Binding IsExpanded}" />
<EventSetter Event="MouseDoubleClick" Handler="treMain_MouseDoubleClick" />
</Style>
</TreeView.ItemContainerStyle>
</TreeView>
興味深い!すぐに働きます。 'GridSplitter'はいつも問題なく私のために働いていたので、私はこのプロパティについて知りませんでした。 – bytecode77