HolonCanvasController.java 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. package ui.controller;
  2. import classes.*;
  3. import ui.model.Model;
  4. import java.awt.*;
  5. import java.util.ArrayList;
  6. public class HolonCanvasController {
  7. // Ball objects
  8. private ArrayList<HolonBody> bodies = new ArrayList<>();
  9. private int subCount;
  10. private Dimension center;
  11. private Model model;
  12. private ArrayList<HolonBody> sortedSize = new ArrayList<>();
  13. private ArrayList<HolonBody> sortedDist = new ArrayList<>();
  14. private int toDrag;
  15. private boolean beingDragged;
  16. /**
  17. * Constructor.
  18. *
  19. * @param model
  20. * the Model
  21. * @param mp
  22. * the MultipurposeController
  23. */
  24. public HolonCanvasController(Model model) {
  25. this.model = model;
  26. }
  27. // sort the HolonBodys after size
  28. public void rearrangeAfterSize() {
  29. int j = 0;
  30. sortedSize.addAll(bodies);
  31. insertionSizeSort(sortedSize);
  32. sortedDist.addAll(bodies);
  33. ArrayList<Vector2d> pos = insertionDistSort(sortedDist);
  34. for (int i = 0; i < subCount; i++) {
  35. int ID = sortedSize.get(subCount - 1 - i).getId();
  36. for (j = 0; j < subCount; j++) {
  37. if (ID == bodies.get(j).getId()) {
  38. bodies.get(j).position = pos.get(i);
  39. break;
  40. }
  41. }
  42. }
  43. }
  44. public int getActiveElements(ArrayList<AbstractCanvasObject> objects) {
  45. int val = 0;
  46. for (AbstractCanvasObject obj : objects) {
  47. if (obj instanceof HolonObject) {
  48. for (HolonElement ele : ((HolonObject) obj).getElements()) {
  49. if (ele.isActive()) {
  50. val += 1;
  51. }
  52. }
  53. } else if (obj instanceof GroupNode) {
  54. val += getTotalProduction(((GroupNode) obj).getNodes());
  55. }
  56. }
  57. return val;
  58. }
  59. public int getTotalProducers(ArrayList<AbstractCanvasObject> objects) {
  60. float val = 0;
  61. int prod = 0;
  62. int tStep = model.getCurIteration();
  63. for (AbstractCanvasObject obj : objects) {
  64. if (obj instanceof HolonObject) {
  65. for (HolonElement ele : ((HolonObject) obj).getElements()) {
  66. if (ele.getEnergyAtTimeStep(tStep) > 0 && ele.isActive()) {
  67. val += ele.getEnergyAtTimeStep(tStep) * ele.getAmount();
  68. }
  69. }
  70. if (val > 0)
  71. prod += 1;
  72. } else if (obj instanceof GroupNode) {
  73. val += getTotalProduction(((GroupNode) obj).getNodes());
  74. }
  75. }
  76. return prod;
  77. }
  78. public int getTotalElements(ArrayList<AbstractCanvasObject> objects) {
  79. int val = 0;
  80. for (AbstractCanvasObject obj : objects) {
  81. if (obj instanceof HolonObject) {
  82. val += ((HolonObject) obj).getElements().size();
  83. } else if (obj instanceof GroupNode) {
  84. val += getTotalConsumption(((GroupNode) obj).getNodes());
  85. }
  86. }
  87. return val;
  88. }
  89. public float getTotalConsumption(ArrayList<AbstractCanvasObject> objects) {
  90. float val = 0;
  91. int tStep = model.getCurIteration();
  92. for (AbstractCanvasObject obj : objects) {
  93. if (obj instanceof HolonObject) {
  94. for (HolonElement ele : ((HolonObject) obj).getElements()) {
  95. if (ele.getEnergyAtTimeStep(tStep) < 0 && ele.isActive()) {
  96. val += ele.getEnergyAtTimeStep(tStep) * ele.getAmount();
  97. }
  98. }
  99. } else if (obj instanceof GroupNode) {
  100. val += getTotalConsumption(((GroupNode) obj).getNodes());
  101. }
  102. }
  103. return val;
  104. }
  105. public float getTotalProduction(ArrayList<AbstractCanvasObject> objects) {
  106. float val = 0;
  107. int tStep = model.getCurIteration();
  108. for (AbstractCanvasObject obj : objects) {
  109. if (obj instanceof HolonObject) {
  110. for (HolonElement ele : ((HolonObject) obj).getElements()) {
  111. if (ele.getEnergyAtTimeStep(tStep) > 0 && ele.isActive()) {
  112. val += ele.getEnergyAtTimeStep(tStep) * ele.getAmount();
  113. }
  114. }
  115. } else if (obj instanceof GroupNode) {
  116. val += getTotalProduction(((GroupNode) obj).getNodes());
  117. }
  118. }
  119. return val;
  120. }
  121. public void updateBodies(float elapsedSeconds) {
  122. // step the position of movable objects based off their velocity/gravity
  123. // and elapsedTime
  124. for (int i = 0; i < subCount; i++) {
  125. if (toDrag != bodies.get(i).getId() || !beingDragged) {
  126. bodies.get(i).position.setX(
  127. (float) (bodies.get(i).position.getX() + (bodies.get(i).velocity.getX() * (elapsedSeconds))
  128. - ((bodies.get(i).position.getX() - center.getWidth()) / (50 + subCount))));
  129. bodies.get(i).position.setY(
  130. (float) (bodies.get(i).position.getY() + (bodies.get(i).velocity.getY() * (elapsedSeconds))
  131. - ((bodies.get(i).position.getY() - center.getHeight()) / (50 + subCount))));
  132. float epsilon = 0.000009f;
  133. if (Math.abs(bodies.get(i).velocity.getX()) < epsilon)
  134. bodies.get(i).velocity.setX(0);
  135. if (Math.abs(bodies.get(i).velocity.getY()) < epsilon)
  136. bodies.get(i).velocity.setY(0);
  137. }
  138. }
  139. checkCollisions();
  140. }
  141. // Insertion sort for Sweep and Prune
  142. public void insertionSort(ArrayList<HolonBody> a) {
  143. for (int p = 1; p < subCount; p++) {
  144. Comparable<HolonBody> tmp = a.get(p);
  145. int j = p;
  146. for (; j > 0 && tmp.compareTo(a.get(j - 1)) < 0; j--)
  147. a.set(j, a.get(j - 1));
  148. a.set(j, (HolonBody) tmp);
  149. }
  150. }
  151. // Insertion sort for subnet size
  152. private void insertionSizeSort(ArrayList<HolonBody> a) {
  153. for (int p = 1; p < subCount; p++) {
  154. HolonBody tmp = a.get(p);
  155. int j = p;
  156. for (; j > 0 && tmp.compareSizeTo(a.get(j - 1)) < 0; j--)
  157. a.set(j, a.get(j - 1));
  158. a.set(j, (HolonBody) tmp);
  159. }
  160. }
  161. // Insertion sort for HolonBody distance
  162. private ArrayList<Vector2d> insertionDistSort(ArrayList<HolonBody> a) {
  163. ArrayList<Vector2d> pos = new ArrayList<>();
  164. for (int p = 1; p < subCount; p++) {
  165. HolonBody tmp = a.get(p);
  166. int j = p;
  167. for (; j > 0 && tmp.compareDistTo(a.get(j - 1), center) < 0; j--)
  168. a.set(j, a.get(j - 1));
  169. a.set(j, (HolonBody) tmp);
  170. }
  171. for (int i = 0; i < subCount; i++)
  172. pos.add(a.get(i).position);
  173. return pos;
  174. }
  175. public void checkCollisions() {
  176. insertionSort(bodies);
  177. for (int i = 0; i < subCount; i++) {
  178. // Ball to Ball collision
  179. float radiusI = bodies.get(i).getRadius();
  180. float xPlusradius = (bodies.get(i).position.getX() + radiusI);
  181. float yPlusradius = (bodies.get(i).position.getY() + radiusI);
  182. float yMinusRadius = (bodies.get(i).position.getY()- radiusI);
  183. for (int j = i + 1; j < subCount; j++) {
  184. float radiusJ = bodies.get(j).getRadius();
  185. if (xPlusradius < (bodies.get(j).position.getX()- radiusJ))
  186. break;
  187. if (yPlusradius < (bodies.get(j).position.getY()- radiusJ)
  188. || (bodies.get(j).position.getY() + radiusJ) < yMinusRadius)
  189. continue;
  190. bodies.get(i).resolveCollision(bodies.get(j));
  191. }
  192. }
  193. }
  194. public ArrayList<HolonBody> getBodies() {
  195. return bodies;
  196. }
  197. public void setDrag(boolean beingDragged) {
  198. this.beingDragged = beingDragged;
  199. }
  200. public void setBodyToDrag(int i) {
  201. this.toDrag = i;
  202. }
  203. }