BehaviorTreeView.xaml 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <UserControl xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  2. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  3. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  4. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  5. xmlns:Tree="clr-namespace:Tree"
  6. x:Class="Tree.BehaviorTreeView"
  7. mc:Ignorable="d"
  8. d:DesignHeight="800"
  9. d:DesignWidth="1280"
  10. d:DataContext="{d:DesignInstance Tree:BehaviorTreeViewModel}">
  11. <UserControl.Resources>
  12. <LinearGradientBrush x:Key="treeNodeSelectorFillBrush" StartPoint="0,0" EndPoint="0,1">
  13. <GradientStop Color="White" Offset="0" />
  14. <GradientStop Color="#FFF37FFF" Offset="0.6" />
  15. </LinearGradientBrush>
  16. <LinearGradientBrush x:Key="treeNodeOtherFillBrush" StartPoint="0,0" EndPoint="0,1">
  17. <GradientStop Color="White" Offset="0" />
  18. <GradientStop Color="#FFF59202" Offset="0.6" />
  19. </LinearGradientBrush>
  20. <LinearGradientBrush x:Key="treeNodeActionFillBrush" StartPoint="0,0" EndPoint="0,1">
  21. <GradientStop Color="White" Offset="0" />
  22. <GradientStop Color="#FF06F31C" Offset="0.6" />
  23. </LinearGradientBrush>
  24. <LinearGradientBrush x:Key="treeNodeSequenceFillBrush" StartPoint="0,0" EndPoint="0,1">
  25. <GradientStop Color="White" Offset="0" />
  26. <GradientStop Color="#FFF3EF91" Offset="0.6" />
  27. </LinearGradientBrush>
  28. <LinearGradientBrush x:Key="treeNodeConditionFillBrush" StartPoint="0,0" EndPoint="0,1">
  29. <GradientStop Color="White" Offset="0" />
  30. <GradientStop Color="#FF06CBF7" Offset="0.6" />
  31. </LinearGradientBrush>
  32. <SolidColorBrush x:Key="treeNodeBorderBrush" Color="Black" />
  33. <Tree:NodeTypeColorConverter x:Key="NodeTypeColorConverter"/>
  34. <Tree:NodeTypeToStringConverter x:Key="NodeTypeToStringConverter"/>
  35. <Tree:FolderVisiableConverter x:Key="FolderVisiableConverter"/>
  36. </UserControl.Resources>
  37. <UserControl.CommandBindings>
  38. <CommandBinding Command="ApplicationCommands.New" Executed="MenuNode_New" />
  39. <CommandBinding Command="ApplicationCommands.Delete" Executed="MenuNode_Delete" />
  40. <CommandBinding Command="ApplicationCommands.Save" Executed="MenuNode_Save" />
  41. <CommandBinding Command="ApplicationCommands.Open" Executed="MenuNode_Open" />
  42. </UserControl.CommandBindings>
  43. <UserControl.ContextMenu>
  44. <ContextMenu>
  45. <MenuItem Header="新建" Command="ApplicationCommands.New"
  46. CommandTarget="{Binding Path=PlacementTarget, RelativeSource={RelativeSource AncestorType=ContextMenu}}" />
  47. <MenuItem Header="删除" Command="ApplicationCommands.Delete"
  48. CommandTarget="{Binding Path=PlacementTarget, RelativeSource={RelativeSource AncestorType=ContextMenu}}" />
  49. <MenuItem Header="保存" Command="ApplicationCommands.Save"
  50. CommandTarget="{Binding Path=PlacementTarget, RelativeSource={RelativeSource AncestorType=ContextMenu}}" />
  51. <MenuItem Header="打开" Command="ApplicationCommands.Open"
  52. CommandTarget="{Binding Path=PlacementTarget, RelativeSource={RelativeSource AncestorType=ContextMenu}}" />
  53. </ContextMenu>
  54. </UserControl.ContextMenu>
  55. <Grid>
  56. <Grid.ColumnDefinitions>
  57. <ColumnDefinition Width="5*"/>
  58. <ColumnDefinition Width="*"/>
  59. </Grid.ColumnDefinitions>
  60. <ListBox Name="listBox" SelectionMode="Single" ItemsSource="{Binding TreeNodes}">
  61. <ListBox.Resources>
  62. <Style TargetType="{x:Type ListBoxItem}">
  63. <Setter Property="Canvas.Left" Value="{Binding X}" />
  64. <Setter Property="Canvas.Top" Value="{Binding Y}" />
  65. </Style>
  66. </ListBox.Resources>
  67. <ListBox.ItemsPanel>
  68. <ItemsPanelTemplate>
  69. <Canvas AllowDrop="True" />
  70. </ItemsPanelTemplate>
  71. </ListBox.ItemsPanel>
  72. <ListBox.ItemTemplate>
  73. <DataTemplate DataType="Tree:TreeNodeViewModel">
  74. <Canvas MouseDown="ListBoxItem_MouseDown" MouseUp="ListBoxItem_MouseUp" MouseMove="ListBoxItem_MouseMove"
  75. PreviewMouseLeftButtonDown="ListBoxItem_PreviewMouseLeftButtonDown"
  76. PreviewMouseLeftButtonUp="ListBoxItem_PreviewMouseLeftButtonUp">
  77. <Rectangle Name="rectNode" Width="{Binding Width}" Height="{Binding Height}" Cursor="Hand" StrokeThickness="2"
  78. RadiusX="10" RadiusY="10" Stroke="{StaticResource treeNodeBorderBrush}" Fill="{StaticResource treeNodeSelectorFillBrush}"/>
  79. <Label Content="+" Visibility="{Binding IsFolder, Converter={StaticResource FolderVisiableConverter}}" Canvas.Left="60" Canvas.Top="10" ></Label>
  80. <StackPanel>
  81. <Label Content="{Binding Type, Converter={StaticResource NodeTypeToStringConverter}}" ></Label>
  82. <Label Content="{Binding Comment}" ></Label>
  83. </StackPanel>
  84. <Line X1="{Binding ConnectorX1}" Y1="{Binding ConnectorY1}" X2="{Binding ConnectorX2}" Y2="{Binding ConnectorY2}"
  85. Stroke="Black" StrokeThickness="2" />
  86. </Canvas>
  87. <DataTemplate.Triggers>
  88. <DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type ListBoxItem}}, Path=IsSelected}" Value="True">
  89. <Setter TargetName="rectNode" Property="Stroke" Value="Green" />
  90. </DataTrigger>
  91. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="selector">
  92. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeSelectorFillBrush}" />
  93. </DataTrigger>
  94. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="sequence">
  95. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeSequenceFillBrush}" />
  96. </DataTrigger>
  97. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="condition">
  98. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeConditionFillBrush}" />
  99. </DataTrigger>
  100. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="action">
  101. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeActionFillBrush}" />
  102. </DataTrigger>
  103. <DataTrigger Binding="{Binding Type, Converter={StaticResource NodeTypeColorConverter}}" Value="other">
  104. <Setter TargetName="rectNode" Property="Fill" Value="{StaticResource treeNodeOtherFillBrush}" />
  105. </DataTrigger>
  106. </DataTemplate.Triggers>
  107. </DataTemplate>
  108. </ListBox.ItemTemplate>
  109. </ListBox>
  110. <StackPanel Grid.Column="1">
  111. <Tree:NodeDataEditor x:Name="nodeDataEditor" />
  112. </StackPanel>
  113. </Grid>
  114. </UserControl>