BehaviorTreeViewModel.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. using System.Collections.Generic;
  2. using System.Collections.ObjectModel;
  3. using System.ComponentModel.Composition;
  4. namespace Tree
  5. {
  6. [Export(contractType: typeof (BehaviorTreeViewModel)),
  7. PartCreationPolicy(creationPolicy: CreationPolicy.NonShared)]
  8. internal class BehaviorTreeViewModel
  9. {
  10. private readonly ObservableCollection<TreeNodeViewModel> treeNodes =
  11. new ObservableCollection<TreeNodeViewModel>();
  12. // 保存折叠节点的孩子节点
  13. private readonly Dictionary<TreeNodeViewModel, ObservableCollection<TreeNodeViewModel>>
  14. folderNodeChildren = new Dictionary<TreeNodeViewModel, ObservableCollection<TreeNodeViewModel>>();
  15. public ObservableCollection<TreeNodeViewModel> TreeNodes
  16. {
  17. get
  18. {
  19. return this.treeNodes;
  20. }
  21. }
  22. private TreeNodeViewModel Root
  23. {
  24. get
  25. {
  26. return this.treeNodes.Count == 0? null : this.treeNodes[0];
  27. }
  28. }
  29. public void Add(TreeNode treeNode, TreeNodeViewModel parent)
  30. {
  31. // 如果父节点是折叠的,需要先展开父节点
  32. if (parent != null && parent.IsFolder)
  33. {
  34. UnFold(parent);
  35. }
  36. var treeNodeViewModel = new TreeNodeViewModel(treeNode, parent);
  37. this.treeNodes.Add(treeNodeViewModel);
  38. if (parent != null)
  39. {
  40. parent.Children.Add(treeNodeViewModel);
  41. }
  42. BehaviorTreeLayout.ExcuteLayout(this.Root);
  43. }
  44. private void RecursionRemove(TreeNodeViewModel treeNodeViewModel)
  45. {
  46. for (int i = treeNodeViewModel.Children.Count - 1; i >= 0; --i)
  47. {
  48. this.RecursionRemove(treeNodeViewModel.Children[i]);
  49. }
  50. this.treeNodes.Remove(treeNodeViewModel);
  51. }
  52. public void Remove(TreeNodeViewModel treeNodeViewModel)
  53. {
  54. this.RecursionRemove(treeNodeViewModel);
  55. treeNodeViewModel.Parent.Children.Remove(treeNodeViewModel);
  56. BehaviorTreeLayout.ExcuteLayout(this.Root);
  57. }
  58. private void RecursionMove(TreeNodeViewModel treeNodeViewModel, double offsetX, double offsetY)
  59. {
  60. treeNodeViewModel.X += offsetX;
  61. treeNodeViewModel.Y += offsetY;
  62. foreach (var node in treeNodeViewModel.Children)
  63. {
  64. this.RecursionMove(node, offsetX, offsetY);
  65. }
  66. }
  67. public void MoveToPosition(double offsetX, double offsetY)
  68. {
  69. this.RecursionMove(this.Root, offsetX, offsetY);
  70. }
  71. public void MoveToNode(TreeNodeViewModel from, TreeNodeViewModel to)
  72. {
  73. from.Parent.Children.Remove(from);
  74. to.Children.Add(from);
  75. from.Parent = to;
  76. BehaviorTreeLayout.ExcuteLayout(this.Root);
  77. }
  78. /// <summary>
  79. /// 折叠节点
  80. /// </summary>
  81. /// <param name="treeNodeViewModel"></param>
  82. public void Fold(TreeNodeViewModel treeNodeViewModel)
  83. {
  84. this.folderNodeChildren[treeNodeViewModel] = treeNodeViewModel.Children;
  85. foreach (var node in treeNodeViewModel.Children)
  86. {
  87. this.RecursionRemove(node);
  88. }
  89. treeNodeViewModel.IsFolder = true;
  90. BehaviorTreeLayout.ExcuteLayout(this.Root);
  91. }
  92. /// <summary>
  93. /// 展开节点
  94. /// </summary>
  95. /// <param name="treeNodeViewModel"></param>
  96. public void UnFold(TreeNodeViewModel treeNodeViewModel)
  97. {
  98. ObservableCollection<TreeNodeViewModel> children = this.folderNodeChildren[treeNodeViewModel];
  99. foreach (var tn in children)
  100. {
  101. this.RecursionAdd(tn);
  102. }
  103. treeNodeViewModel.IsFolder = false;
  104. BehaviorTreeLayout.ExcuteLayout(this.Root);
  105. }
  106. private void RecursionAdd(TreeNodeViewModel treeNodeViewModel)
  107. {
  108. this.treeNodes.Add(treeNodeViewModel);
  109. ObservableCollection<TreeNodeViewModel> children = treeNodeViewModel.Children;
  110. foreach (var tn in children)
  111. {
  112. this.RecursionAdd(tn);
  113. }
  114. }
  115. }
  116. }