TreeView.xaml 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <UserControl x:Class="Modules.Tree.TreeView"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  5. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  6. xmlns:tree="clr-namespace:Modules.Tree"
  7. mc:Ignorable="d"
  8. d:DesignHeight="300" d:DesignWidth="300"
  9. d:DataContext="{d:DesignInstance tree:TreeViewModel}">
  10. <UserControl.Resources>
  11. <LinearGradientBrush x:Key="treeNodeSelectorFillBrush" StartPoint="0,0" EndPoint="0,1">
  12. <GradientStop Color="White" Offset="0" />
  13. <GradientStop Color="#FFF37FFF" Offset="0.6" />
  14. </LinearGradientBrush>
  15. <LinearGradientBrush x:Key="treeNodeOtherFillBrush" StartPoint="0,0" EndPoint="0,1">
  16. <GradientStop Color="White" Offset="0" />
  17. <GradientStop Color="#FFF59202" Offset="0.6" />
  18. </LinearGradientBrush>
  19. <LinearGradientBrush x:Key="treeNodeActionFillBrush" StartPoint="0,0" EndPoint="0,1">
  20. <GradientStop Color="White" Offset="0" />
  21. <GradientStop Color="#FF06F31C" Offset="0.6" />
  22. </LinearGradientBrush>
  23. <LinearGradientBrush x:Key="treeNodeSequenceFillBrush" StartPoint="0,0" EndPoint="0,1">
  24. <GradientStop Color="White" Offset="0" />
  25. <GradientStop Color="#FFF3EF91" Offset="0.6" />
  26. </LinearGradientBrush>
  27. <LinearGradientBrush x:Key="treeNodeConditionFillBrush" StartPoint="0,0" EndPoint="0,1">
  28. <GradientStop Color="White" Offset="0" />
  29. <GradientStop Color="#FF06CBF7" Offset="0.6" />
  30. </LinearGradientBrush>
  31. <SolidColorBrush x:Key="treeNodeBorderBrush" Color="Black" />
  32. <tree:NodeTypeColorConverter x:Key="NodeTypeColorConverter"/>
  33. <tree:NodeTypeToStringConverter x:Key="NodeTypeToStringConverter"/>
  34. <tree:FolderVisiableConverter x:Key="FolderVisiableConverter"/>
  35. </UserControl.Resources>
  36. <Grid>
  37. <ListBox Name="listBox" SelectionMode="Single" ItemsSource="{Binding TreeNodes}" VerticalAlignment="Stretch">
  38. <ListBox.ContextMenu>
  39. <ContextMenu>
  40. <MenuItem Header="新建" Click="MenuItem_New" />
  41. <MenuItem Header="删除" Click="MenuItem_Remove" />
  42. <MenuItem Header="左移" Click="MenuItem_MoveLeft" />
  43. <MenuItem Header="右移" Click="MenuItem_MoveRight" />
  44. <MenuItem Header="折叠/展开" Click="MenuItem_Fold" />
  45. </ContextMenu>
  46. </ListBox.ContextMenu>
  47. <ListBox.Resources>
  48. <Style TargetType="{x:Type ListBoxItem}">
  49. <Setter Property="Canvas.Left" Value="{Binding X}" />
  50. <Setter Property="Canvas.Top" Value="{Binding Y}" />
  51. </Style>
  52. </ListBox.Resources>
  53. <ListBox.ItemsPanel>
  54. <ItemsPanelTemplate>
  55. <Canvas AllowDrop="True" />
  56. </ItemsPanelTemplate>
  57. </ListBox.ItemsPanel>
  58. <ListBox.ItemTemplate>
  59. <DataTemplate DataType="tree:TreeNodeViewModel">
  60. <Canvas MouseDown="ListBoxItem_MouseDown" MouseUp="ListBoxItem_MouseUp" MouseMove="ListBoxItem_MouseMove"
  61. PreviewMouseLeftButtonDown="ListBoxItem_PreviewMouseLeftButtonDown"
  62. PreviewMouseLeftButtonUp="ListBoxItem_PreviewMouseLeftButtonUp">
  63. <Rectangle Name="rectNode" Width="{Binding Width}" Height="{Binding Height}" Cursor="Hand" StrokeThickness="2"
  64. RadiusX="10" RadiusY="10" Stroke="{StaticResource treeNodeBorderBrush}" Fill="{StaticResource treeNodeSelectorFillBrush}"/>
  65. <Label Content="+" Visibility="{Binding IsFold, Converter={StaticResource FolderVisiableConverter}}" Canvas.Left="60" Canvas.Top="10"/>
  66. <StackPanel>
  67. <Label Content="{Binding Type, Converter={StaticResource NodeTypeToStringConverter}}"/>
  68. <Label Content="{Binding Comment}"/>
  69. </StackPanel>
  70. <Line X1="{Binding ConnectorX1}" Y1="{Binding ConnectorY1}" X2="{Binding ConnectorX2}" Y2="{Binding ConnectorY2}"
  71. Stroke="Black" StrokeThickness="2" />
  72. </Canvas>
  73. <DataTemplate.Triggers>
  74. <DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type ListBoxItem}}, Path=IsSelected}" Value="True">
  75. <Setter TargetName="rectNode" Property="Stroke" Value="Green" />
  76. </DataTrigger>
  77. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="selector">
  78. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeSelectorFillBrush}" />
  79. </DataTrigger>
  80. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="sequence">
  81. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeSequenceFillBrush}" />
  82. </DataTrigger>
  83. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="condition">
  84. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeConditionFillBrush}" />
  85. </DataTrigger>
  86. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="action">
  87. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeActionFillBrush}" />
  88. </DataTrigger>
  89. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="other">
  90. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeOtherFillBrush}" />
  91. </DataTrigger>
  92. </DataTemplate.Triggers>
  93. </DataTemplate>
  94. </ListBox.ItemTemplate>
  95. </ListBox>
  96. </Grid>
  97. </UserControl>