NodeController.java 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  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. * Put selected Nodes inside the Upper Node
  55. *
  56. * @param node
  57. */
  58. private void makeNodeOfNodes(CpsUpperNode node, CpsUpperNode upperNode) {
  59. ArrayList<AbstractCpsObject> nodes = node.getNodes();
  60. ArrayList<CpsEdge> nodeEdges = node.getNodeEdges();
  61. HashMap<Integer, Integer> nodeIdx = node.getNodesIdx();
  62. // Put all selected Nodes into the Upper Node
  63. for (Iterator<AbstractCpsObject> it = model.getSelectedCpsObjects().iterator(); it.hasNext();) {
  64. AbstractCpsObject obj = it.next();
  65. nodeIdx.put(obj.getID(), nodes.size());
  66. nodes.add(obj);
  67. }
  68. // remove selected nodes
  69. for (Iterator<CpsEdge> it = (upperNode == null ? model.getEdgesOnCanvas() : upperNode.getNodeEdges())
  70. .iterator(); it.hasNext();) {
  71. CpsEdge edge = it.next();
  72. if (nodes.contains(edge.getA()) && nodes.contains(edge.getB())) {
  73. nodeEdges.add(edge);
  74. }
  75. }
  76. for (AbstractCpsObject abs : model.getSelectedCpsObjects()) {
  77. if (upperNode == null)
  78. cvs.deleteObjectOnCanvas(abs);
  79. else
  80. // MUSS GEÄNDERT WERDEN!!!!!!!!!!!!!!!!!
  81. upperNode.getNodes().remove(abs);
  82. }
  83. }
  84. /**
  85. *
  86. * @return
  87. */
  88. private void connectAdjacent(CpsUpperNode node, CpsUpperNode upperNode) {
  89. ArrayList<AbstractCpsObject> adj = new ArrayList<>();
  90. ArrayList<Float> maxCapacity = new ArrayList<>();
  91. ArrayList<CpsEdge> oldEdges = node.getOldEdges();
  92. ArrayList<CpsEdge> toDelete = new ArrayList<>();
  93. // float maxCapacity = 0;
  94. // für alle Edges auf dem Canvas
  95. for (Iterator<CpsEdge> it = model.getEdgesOnCanvas().iterator(); it.hasNext();) {
  96. CpsEdge edge = it.next();
  97. // if (edge.getCapacity() > maxCapacity)
  98. // maxCapacity = edge.getCapacity();
  99. // wenn ausgewählte Objekte in edge und andere auserhalb
  100. if (model.getSelectedCpsObjects().contains(edge.getA())
  101. && !model.getSelectedCpsObjects().contains(edge.getB())) {
  102. // und wenn in der adj noch nicht vorhanden und füg
  103. if (!adj.contains(edge.getB())) {
  104. adj.add(edge.getB());
  105. maxCapacity.add(edge.getCapacity());
  106. }
  107. // wenn vorhanden teste maxCapacity
  108. else if (maxCapacity.get(adj.indexOf(edge.getB())) < edge.getCapacity()) {
  109. maxCapacity.set(adj.indexOf(edge.getB()), edge.getCapacity());
  110. }
  111. // speichere alte edge
  112. oldEdges.add(edge);
  113. toDelete.add(edge);
  114. }
  115. // Analog
  116. else if (!model.getSelectedCpsObjects().contains(edge.getA())
  117. && model.getSelectedCpsObjects().contains(edge.getB())) {
  118. if (!adj.contains(edge.getA())) {
  119. adj.add(edge.getA());
  120. maxCapacity.add(edge.getCapacity());
  121. } else if (maxCapacity.get(adj.indexOf(edge.getA())) < edge.getCapacity()) {
  122. maxCapacity.set(adj.indexOf(edge.getA()), edge.getCapacity());
  123. }
  124. oldEdges.add(edge);
  125. toDelete.add(edge);
  126. }
  127. }
  128. model.getEdgesOnCanvas().removeAll(toDelete);
  129. // für alle objekte in adjazenzliste mach
  130. for (AbstractCpsObject cps : adj) {
  131. CpsEdge newEdge = new CpsEdge(cps, node, maxCapacity.get(adj.indexOf(cps)));
  132. // !! Eventuell noch bei getConnections() hinzufügem
  133. if (upperNode == null)
  134. cvs.addEdgeOnCanvas(newEdge);
  135. else
  136. upperNode.getNodeEdges().add(newEdge);
  137. node.getConnections().add(newEdge);
  138. }
  139. }
  140. /**
  141. * Calculate new Position of the Upper Node
  142. *
  143. * @return
  144. */
  145. private Position calculatePos() {
  146. Position pos = new Position(0, 0);
  147. // sum(x0 .. xn) / numOfPos, y analog
  148. for (AbstractCpsObject abs : model.getSelectedCpsObjects()) {
  149. pos.x += abs.getPosition().x;
  150. pos.y += abs.getPosition().y;
  151. }
  152. pos.x /= model.getSelectedCpsObjects().size();
  153. pos.y /= model.getSelectedCpsObjects().size();
  154. return pos;
  155. }
  156. }