NodeController.java 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. package ui.controller;
  2. import java.util.ArrayList;
  3. import java.util.HashMap;
  4. import java.util.Iterator;
  5. import classes.AbstractCpsObject;
  6. import classes.CpsEdge;
  7. import classes.CpsUpperNode;
  8. import classes.Position;
  9. import ui.model.Model;
  10. public class NodeController {
  11. private Model model;
  12. private CanvasController cvs;
  13. private MultiPurposeController mpC;
  14. public NodeController(Model model, CanvasController cvs, MultiPurposeController mpC) {
  15. // TODO Auto-generated constructor stub
  16. this.model = model;
  17. this.cvs = cvs;
  18. this.mpC = mpC;
  19. }
  20. /**
  21. * Add a CpsUpperNode into Canvas
  22. *
  23. * @param nodeName
  24. */
  25. public void addNode(String nodeName, CpsUpperNode upperNode) {
  26. CpsUpperNode node = new CpsUpperNode(nodeName);
  27. node.setPosition(calculatePos());
  28. connectAdjacent(node, upperNode);
  29. makeNodeOfNodes(node, upperNode);
  30. if (upperNode == null)
  31. cvs.addNewObject(node);
  32. else
  33. addObjectInUpperNode(node, upperNode);
  34. }
  35. /**
  36. * Add a Object into a CpsUpperNode
  37. *
  38. * @param object
  39. * @param upperNode
  40. */
  41. public void addObjectInUpperNode(AbstractCpsObject object, CpsUpperNode upperNode) {
  42. object.setSav("UPPER" + upperNode.getID());
  43. upperNode.getNodesIdx().put(object.getID(), upperNode.getNodes().size());
  44. upperNode.getNodes().add(object);
  45. }
  46. /**
  47. * Delete a CpsUpperNode from the Canvas
  48. *
  49. * @param node
  50. */
  51. public void deleteNode(CpsUpperNode node) {
  52. }
  53. /**
  54. * Delete a AbstactCpsObject from CPSUpperNode
  55. *
  56. * @param object
  57. * @param upperNode
  58. */
  59. public void deleteObjectInUpperNode(AbstractCpsObject object, CpsUpperNode upperNode) {
  60. CpsEdge e = null;
  61. for (AbstractCpsObject cps : upperNode.getNodes()) {
  62. for (CpsEdge p : cps.getConnections()) {
  63. if (p.getA() == object || p.getB() == object) {
  64. e = p;
  65. }
  66. }
  67. if (!model.getClipboradObjects().contains(cps)) {
  68. cps.getConnectedTo().remove(e);
  69. }
  70. model.getEdgesOnCanvas().remove(e);
  71. }
  72. mpC.decIdx(object.getID(), upperNode.getNodesIdx());
  73. upperNode.getNodesIdx().remove(object.getID());
  74. upperNode.getNodes().remove(object);
  75. }
  76. /**
  77. * Put selected Nodes inside the Upper Node
  78. *
  79. * @param node
  80. */
  81. private void makeNodeOfNodes(CpsUpperNode node, CpsUpperNode upperNode) {
  82. ArrayList<AbstractCpsObject> nodes = node.getNodes();
  83. ArrayList<CpsEdge> nodeEdges = node.getNodeEdges();
  84. // Put all selected Nodes into the Upper Node
  85. for (Iterator<AbstractCpsObject> it = model.getSelectedCpsObjects().iterator(); it.hasNext();) {
  86. // füge Neue Objecte in Neuen Node hinzu
  87. AbstractCpsObject obj = it.next();
  88. addObjectInUpperNode(obj, node);
  89. }
  90. // Füge die Edges die Alle Objekte vorher verbunden hat in neuen Node
  91. for (Iterator<CpsEdge> it = (upperNode == null ? model.getEdgesOnCanvas() : upperNode.getNodeEdges())
  92. .iterator(); it.hasNext();) {
  93. CpsEdge edge = it.next();
  94. if (nodes.contains(edge.getA()) && nodes.contains(edge.getB())) {
  95. nodeEdges.add(edge);
  96. }
  97. }
  98. // Lösche dann die Edges aus der nächst höheren schicht
  99. for (AbstractCpsObject abs : model.getSelectedCpsObjects()) {
  100. if (upperNode == null)
  101. cvs.deleteObjectOnCanvas(abs);
  102. else
  103. deleteObjectInUpperNode(abs, upperNode);
  104. }
  105. }
  106. /**
  107. *
  108. * @return
  109. */
  110. private void connectAdjacent(CpsUpperNode node, CpsUpperNode upperNode) {
  111. ArrayList<AbstractCpsObject> adj = new ArrayList<>();
  112. ArrayList<Float> maxCapacity = new ArrayList<>();
  113. ArrayList<CpsEdge> oldEdges = node.getOldEdges();
  114. ArrayList<CpsEdge> toDelete = new ArrayList<>();
  115. // float maxCapacity = 0;
  116. // für alle Edges auf dem Canvas
  117. for (Iterator<CpsEdge> it = model.getEdgesOnCanvas().iterator(); it.hasNext();) {
  118. CpsEdge edge = it.next();
  119. // if (edge.getCapacity() > maxCapacity)
  120. // maxCapacity = edge.getCapacity();
  121. // wenn ausgewählte Objekte in edge und andere auserhalb
  122. if (model.getSelectedCpsObjects().contains(edge.getA())
  123. && !model.getSelectedCpsObjects().contains(edge.getB())) {
  124. // und wenn in der adj noch nicht vorhanden und füg
  125. if (!adj.contains(edge.getB())) {
  126. adj.add(edge.getB());
  127. maxCapacity.add(edge.getCapacity());
  128. }
  129. // wenn vorhanden teste maxCapacity
  130. else if (maxCapacity.get(adj.indexOf(edge.getB())) < edge.getCapacity()) {
  131. maxCapacity.set(adj.indexOf(edge.getB()), edge.getCapacity());
  132. }
  133. // speichere alte edge
  134. oldEdges.add(edge);
  135. toDelete.add(edge);
  136. }
  137. // Analog
  138. else if (!model.getSelectedCpsObjects().contains(edge.getA())
  139. && model.getSelectedCpsObjects().contains(edge.getB())) {
  140. if (!adj.contains(edge.getA())) {
  141. adj.add(edge.getA());
  142. maxCapacity.add(edge.getCapacity());
  143. } else if (maxCapacity.get(adj.indexOf(edge.getA())) < edge.getCapacity()) {
  144. maxCapacity.set(adj.indexOf(edge.getA()), edge.getCapacity());
  145. }
  146. oldEdges.add(edge);
  147. toDelete.add(edge);
  148. }
  149. }
  150. model.getEdgesOnCanvas().removeAll(toDelete);
  151. // für alle objekte in adjazenzliste mach
  152. for (AbstractCpsObject cps : adj) {
  153. CpsEdge newEdge = new CpsEdge(cps, node, maxCapacity.get(adj.indexOf(cps)));
  154. // !! Eventuell noch bei getConnections() hinzufügem
  155. node.getConnections().add(newEdge);
  156. if (upperNode == null)
  157. cvs.addEdgeOnCanvas(newEdge);
  158. else
  159. upperNode.getNodeEdges().add(newEdge);
  160. }
  161. }
  162. /**
  163. * Calculate new Position of the Upper Node
  164. *
  165. * @return
  166. */
  167. private Position calculatePos() {
  168. Position pos = new Position(0, 0);
  169. // sum(x0 .. xn) / numOfPos, y analog
  170. for (AbstractCpsObject abs : model.getSelectedCpsObjects()) {
  171. pos.x += abs.getPosition().x;
  172. pos.y += abs.getPosition().y;
  173. }
  174. pos.x /= model.getSelectedCpsObjects().size();
  175. pos.y /= model.getSelectedCpsObjects().size();
  176. return pos;
  177. }
  178. }