HolonCanvasController.java 6.9 KB

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