BehaviorTreeViewModel.cs 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  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. if (from.IsFolder)
  74. {
  75. this.UnFold(from);
  76. }
  77. // from节点不能是to节点的父级节点
  78. TreeNodeViewModel tmpNode = to;
  79. while (tmpNode != null)
  80. {
  81. if (tmpNode.IsRoot)
  82. {
  83. break;
  84. }
  85. if (tmpNode.Num == from.Num)
  86. {
  87. return;
  88. }
  89. tmpNode = tmpNode.Parent;
  90. }
  91. from.Parent.Children.Remove(from);
  92. to.Children.Add(from);
  93. from.Parent = to;
  94. BehaviorTreeLayout.ExcuteLayout(this.Root);
  95. }
  96. /// <summary>
  97. /// 折叠节点
  98. /// </summary>
  99. /// <param name="treeNodeViewModel"></param>
  100. public void Fold(TreeNodeViewModel treeNodeViewModel)
  101. {
  102. this.folderNodeChildren[treeNodeViewModel] = treeNodeViewModel.Children;
  103. foreach (var node in treeNodeViewModel.Children)
  104. {
  105. this.RecursionRemove(node);
  106. }
  107. treeNodeViewModel.IsFolder = true;
  108. BehaviorTreeLayout.ExcuteLayout(this.Root);
  109. }
  110. /// <summary>
  111. /// 展开节点
  112. /// </summary>
  113. /// <param name="treeNodeViewModel"></param>
  114. public void UnFold(TreeNodeViewModel treeNodeViewModel)
  115. {
  116. ObservableCollection<TreeNodeViewModel> children = this.folderNodeChildren[treeNodeViewModel];
  117. foreach (var tn in children)
  118. {
  119. this.RecursionAdd(tn);
  120. }
  121. treeNodeViewModel.IsFolder = false;
  122. BehaviorTreeLayout.ExcuteLayout(this.Root);
  123. }
  124. private void RecursionAdd(TreeNodeViewModel treeNodeViewModel)
  125. {
  126. this.treeNodes.Add(treeNodeViewModel);
  127. ObservableCollection<TreeNodeViewModel> children = treeNodeViewModel.Children;
  128. foreach (var tn in children)
  129. {
  130. this.RecursionAdd(tn);
  131. }
  132. }
  133. }
  134. }