UpdateController.java 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501
  1. package ui.controller;
  2. import classes.*;
  3. import classes.comparator.elementComparator.ElemCompOnEleName;
  4. import classes.comparator.elementComparator.ElemCompOnEnergy;
  5. import classes.comparator.elementComparator.ElemCompOnId;
  6. import classes.comparator.elementComparator.ElemCompOnIsActivated;
  7. import classes.comparator.elementComparator.ElemCompOnObj;
  8. import classes.comparator.elementComparator.ElemCompOnQuantity;
  9. import ui.model.DecoratedGroupNode;
  10. import ui.model.DecoratedHolonObject.HolonObjectState;
  11. import ui.model.Model;
  12. import ui.view.DefaulTable;
  13. import ui.view.Languages;
  14. import ui.view.PropertyTable;
  15. import ui.view.GroupNodeCanvas;
  16. import java.util.ArrayList;
  17. import java.util.HashMap;
  18. import java.util.LinkedList;
  19. /**
  20. * This class is for all update methods and more ;)
  21. *
  22. * @author Gruppe14
  23. *
  24. */
  25. public class UpdateController {
  26. Model model;
  27. Control controller;
  28. private int sortBy;
  29. public UpdateController(Model model, Control control) {
  30. this.model = model;
  31. this.controller = control;
  32. sortBy= 1;
  33. }
  34. /**
  35. * Update the information concerning properties of the selected CpsObject.
  36. */
  37. public void refreshTableProperties(DefaulTable table) {
  38. if (model.getSelectedCpsObjects().size() == 1) {
  39. AbstractCanvasObject tempCps = model.getSelectedCpsObjects().get(0);
  40. if (tempCps != null && tempCps.getClass() == HolonObject.class) {
  41. if (table.getRowCount() != 0) {
  42. table.removeRow(2);
  43. Object[] tempEnergy = { Languages.getLanguage()[73], ((HolonObject) tempCps).getEnergyNeededFromConsumingElements(model.getCurIteration()) };
  44. table.insertRow(2, tempEnergy);
  45. table.removeRow(3);
  46. Object[] tempFlex = { "Flexibility", ((HolonObject) tempCps).getTotalFlex() };
  47. table.insertRow(3, tempFlex);
  48. }
  49. }
  50. }
  51. }
  52. /**
  53. * Add the Information of the given ArrayList in the HolonElement Model as
  54. * Name,Energy and Amount.
  55. *
  56. * @param objects
  57. * ArrayList to be displayed
  58. */
  59. public void fillElementTable(ArrayList<AbstractCanvasObject> objects, PropertyTable table) {
  60. LinkedList<HolonElement> elemList = new LinkedList<HolonElement>();
  61. if (objects.size() > 1) {
  62. for (AbstractCanvasObject o : objects) {
  63. if (o instanceof HolonObject) {
  64. for (HolonElement he : ((HolonObject) o).getElements()) {
  65. he.setObjName(o.getName() + ", " + o.getId());
  66. elemList.add(he);
  67. elemList=sortElemList(elemList);
  68. }
  69. }
  70. }
  71. for (HolonElement e1 : elemList) {
  72. Object[] temp2 = { e1.getObjName(), e1.getId(), e1.getEleName(), e1.getEnergyPerElement(),
  73. controller.getSimManager().getActualFlexManager().isAFlexInUseOfHolonElement(e1), e1.getAmount(), e1.isActive()};
  74. table.addRow(temp2);
  75. }
  76. } else if (objects.size() == 1) {
  77. AbstractCanvasObject o = objects.get(0);
  78. if (o instanceof HolonObject) {
  79. for (HolonElement he : ((HolonObject) o).getElements()) {
  80. elemList.add(he);
  81. elemList=sortElemList(elemList);
  82. }
  83. for (HolonElement e1 : elemList) {
  84. Object[] temp2 = { e1.getId(), e1.getEleName(), e1.getEnergyPerElement(),
  85. controller.getSimManager().getActualFlexManager().isAFlexInUseOfHolonElement(e1), e1.getAmount(), e1.isActive()};
  86. table.addRow(temp2);
  87. }
  88. }
  89. }
  90. }
  91. /**
  92. * @param elemList - HolonElement-List (unsorted)
  93. * @return sorted HolonElement-List!
  94. */
  95. public LinkedList<HolonElement> sortElemList(LinkedList<HolonElement> elemList) {
  96. switch(sortBy) {
  97. case 0://"Object":
  98. elemList.sort(new ElemCompOnObj());
  99. break;
  100. case 1://ID
  101. elemList.sort(new ElemCompOnId());
  102. break;
  103. case 2://"Device":
  104. elemList.sort(new ElemCompOnEleName());
  105. break;
  106. case 3://"Energy":
  107. elemList.sort(new ElemCompOnEnergy());
  108. break;
  109. case 4://"Flexible Energy Available":
  110. elemList.sort(null);
  111. break;
  112. case 5://"Quantity":
  113. elemList.sort(new ElemCompOnQuantity());
  114. break;
  115. case 6://"Activated":
  116. elemList.sort(new ElemCompOnIsActivated());
  117. break;
  118. case 7://"Flexible":
  119. elemList.sort(null);
  120. break;
  121. default:
  122. elemList.sort(new ElemCompOnId());
  123. break;
  124. }
  125. return elemList;
  126. };
  127. /**
  128. * Update the HolonElement Table, that means erase all rows and add the new
  129. * rows with new data.
  130. */
  131. public void refreshTableHolonElement(PropertyTable multiTable, PropertyTable singleTable) {
  132. // Update of the Information about the HolonElements - only for
  133. // HolonObjects
  134. if(multiTable == null || singleTable == null ) return;
  135. if (model.getSelectedCpsObjects().size() > 1) {
  136. deleteRows(multiTable);
  137. fillElementTable(model.getSelectedCpsObjects(), multiTable);
  138. multiTable.fireTableDataChanged();
  139. } else if (model.getSelectedCpsObjects().size() == 1) {
  140. deleteRows(singleTable);
  141. fillElementTable(model.getSelectedCpsObjects(), singleTable);
  142. singleTable.fireTableDataChanged();
  143. }
  144. }
  145. /**
  146. * Erase all information of the HolonElement Model.
  147. *
  148. * @param t
  149. * the Table
  150. */
  151. public void deleteRows(PropertyTable t) {
  152. if (t.getRowCount() > 0) {
  153. for (int i = t.getRowCount() - 1; i > -1; i--) {
  154. t.removeRow(i);
  155. }
  156. }
  157. }
  158. /**
  159. * Search for clicked HolonObject through the mouse's y-Coord.
  160. *
  161. * @param yValue
  162. * the Y Coordination
  163. * @return clicked HolonObject
  164. */
  165. public HolonObject getHolonObj(int yValue, PropertyTable table) {
  166. final int yTemp = (int) Math.floor(yValue / 16);
  167. HolonObject obtTemp = null;
  168. String temp = table.getValueAt(yTemp, 0).toString();
  169. int idTemp = Integer.parseInt(temp.split(", ")[1]);
  170. obtTemp = (HolonObject) controller.searchByID(idTemp);
  171. return obtTemp;
  172. }
  173. /**
  174. * Search for actual selected HolonElement.
  175. *
  176. * @param obj
  177. * selected HolonObject, if obj==null means multi-selection
  178. * active
  179. * @param yValue
  180. * Y-Coord in the HolonElementsTable
  181. * @param toMultiHash
  182. * 0 means no MultiSelection, 1 means MultiSelection without
  183. * Control, 2 means MultiSelection with Control
  184. * @return the selected HolonElement
  185. */
  186. public HolonElement getActualHolonElement(HolonObject obj, int yValue, int toMultiHash,
  187. ArrayList<PropertyTable> tables) {
  188. final int yTemp = (int) Math.floor(yValue / 16);
  189. int rowsTotal = 0;
  190. // Filter for search --> single and multi selection
  191. if (obj == null) {
  192. rowsTotal = tables.get(1).getRowCount();
  193. } else {
  194. rowsTotal = tables.get(0).getRowCount();
  195. }
  196. // search for the clicked HolonObject and HolonElement --> in the
  197. // HolonElementTable
  198. HolonObject obtTemp = null;
  199. HolonElement toReturnEle = null;
  200. int id = 0;
  201. if (rowsTotal != 0 && rowsTotal > yTemp) {
  202. // Multi-Selection search
  203. if (obj == null) {
  204. String tempStringObj = tables.get(1).getValueAt(yTemp, 0).toString();
  205. int idTempObj = Integer.parseInt(tempStringObj.split(", ")[1]);
  206. if (model.getSelectedCpsObjects() != null) {
  207. obtTemp = (HolonObject) getHolonObjSelected(idTempObj);
  208. }
  209. id = Integer.parseInt(tables.get(1).getValueAt(yTemp, 1).toString());
  210. ArrayList<HolonElement> eleTemp = new ArrayList<HolonElement>();
  211. if (model.getEleToDelete().containsKey(idTempObj) && toMultiHash == 2) {
  212. eleTemp = model.getEleToDelete().get(idTempObj);
  213. if (!eleTemp.contains(obtTemp.searchElementById(id))) {
  214. eleTemp.add(obtTemp.searchElementById(id));
  215. model.getEleToDelete().replace(idTempObj, eleTemp);
  216. }
  217. } else if (toMultiHash == 2) {
  218. eleTemp.add(obtTemp.searchElementById(id));
  219. model.getEleToDelete().put(idTempObj, eleTemp);
  220. } else if (toMultiHash == 1) {
  221. model.setEleToDelete(new HashMap<Integer, ArrayList<HolonElement>>());
  222. eleTemp.add(obtTemp.searchElementById(id));
  223. model.getEleToDelete().put(idTempObj, eleTemp);
  224. } else if (toMultiHash == 0) {
  225. toReturnEle = obtTemp.searchElementById(id);
  226. }
  227. } // Single-Selection search
  228. else {
  229. model.setEleToDelete(new HashMap<Integer, ArrayList<HolonElement>>());
  230. id = Integer.parseInt(tables.get(0).getValueAt(yTemp, 0).toString());
  231. toReturnEle = obj.searchElementById(id);
  232. }
  233. model.setSelectedHolonElement(toReturnEle);
  234. return toReturnEle;
  235. } // If no HolonObject selected
  236. else {
  237. model.setEleToDelete(new HashMap<Integer, ArrayList<HolonElement>>());
  238. model.setSelectedHolonElement(null);
  239. return null;
  240. }
  241. }
  242. /**
  243. * Getter for selected CpsObject.
  244. *
  245. * @return selected CpsObject
  246. */
  247. public AbstractCanvasObject getActualCps() {
  248. AbstractCanvasObject tempCps;
  249. if (model.getSelectedCpsObjects().size() == 1) {
  250. tempCps = model.getSelectedCpsObjects().get(0);
  251. } else {
  252. int tempID = model.getSelectedObjectID();
  253. tempCps = controller.searchByID(tempID);
  254. }
  255. return tempCps;
  256. }
  257. /**
  258. * Getter for selected CpsObject.
  259. *
  260. * @return selected CpsObject
  261. */
  262. public AbstractCanvasObject getActualCpsUpperNode(GroupNodeCanvas canvas) {
  263. int tempID = model.getSelectedObjectID();
  264. AbstractCanvasObject tempCps = controller.searchByIDUpperNode(tempID, canvas.upperNode);
  265. return tempCps;
  266. }
  267. public void paintProperties(AbstractCanvasObject obj) {
  268. if (obj != null) {
  269. // Name of the CpsObject
  270. Object[] tempName = { Languages.getLanguage()[72], obj.getName() };
  271. model.getPropertyTable().addRow(tempName);
  272. // Id of the CpsObject
  273. Object[] tempId = { "ID", obj.getId() };
  274. model.getPropertyTable().addRow(tempId);
  275. // For HolonObjects the Total Energy (production or
  276. // consumption) is calculated
  277. if (obj instanceof HolonObject) {
  278. refreshTableHolonElement(model.getMultiTable(), model.getSingleTable());
  279. Object[] tempEnergy = { Languages.getLanguage()[73], ((HolonObject) obj).getEnergyNeededFromConsumingElements(model.getCurIteration()) };
  280. Object[] tempFlex = { "Flexibility", ((HolonObject) obj).getTotalFlex() };
  281. model.getPropertyTable().addRow(tempEnergy);
  282. model.getPropertyTable().addRow(tempFlex);
  283. model.getPropertyTable().setCellEditable(0, 1, false);
  284. model.getPropertyTable().setCellEditable(2, 1, false);
  285. model.getPropertyTable().setCellEditable(3, 1, false);
  286. model.getPropertyTable().setCellEditable(4, 1, false);
  287. } // For HolonSwitches is showed the actual status (active
  288. // or inactive)
  289. else if (obj instanceof HolonSwitch) {
  290. deleteRows(model.getSingleTable());
  291. deleteRows(model.getMultiTable());
  292. Object[] tempMode = { Languages.getLanguage()[74], ((HolonSwitch) obj).getManualMode() };
  293. model.getPropertyTable().addRow(tempMode);
  294. if (((HolonSwitch) obj).getManualMode()) {
  295. Object[] tempActive = { Languages.getLanguage()[75], ((HolonSwitch) obj).getManualState() };
  296. model.getPropertyTable().addRow(tempActive);
  297. model.getPropertyTable().setCellEditable(3, 1, true);
  298. } else {
  299. Object[] tempActive = { Languages.getLanguage()[75],
  300. ((HolonSwitch) obj).getState(model.getCurIteration()) };
  301. model.getPropertyTable().addRow(tempActive);
  302. model.getPropertyTable().setCellEditable(3, 1, false);
  303. }
  304. // unitGraph.repaintWithNewSwitch((HolonSwitch) obj);
  305. // elementGraph.setText(obj.getName());
  306. model.getPropertyTable().setCellEditable(0, 1, true);
  307. model.getPropertyTable().setCellEditable(2, 1, true);
  308. } else if (obj instanceof GroupNode) {
  309. deleteRows(model.getSingleTable());
  310. deleteRows(model.getMultiTable());
  311. //short fix please make me new
  312. DecoratedGroupNode dGroupNode = controller.getSimManager().getVisualRepresentationalState(model.getCurIteration()).getCreatedGroupNodes().get((GroupNode) obj);
  313. Object[] info = { "Statistics:", "" };
  314. Object[] numEle = { "Number of Objects (total)", ((GroupNode) obj).getNodes().size() };
  315. Object[] numObj = { "Number of HolonObjects", ((GroupNode) obj).getNumHolonObj().size() };
  316. Object[] numSwi = { "Number of HolonSwitches", ((GroupNode) obj).getNumSwitches().size() };
  317. Object[] numUpp = { "Number of GroupNodes", ((GroupNode) obj).getNumUpperNodes().size() };
  318. model.getPropertyTable().addRow(info);
  319. model.getPropertyTable().addRow(numEle);
  320. model.getPropertyTable().addRow(numObj);
  321. model.getPropertyTable().addRow(numSwi);
  322. model.getPropertyTable().addRow(numUpp);
  323. if(dGroupNode != null) {
  324. int numerator, denominator;
  325. Object[] title = { "HolonObject Statistics:", "" };
  326. denominator = dGroupNode.getAmountOfConsumer() + dGroupNode.getAmountOfSupplier() + dGroupNode.getAmountOfPassiv();
  327. numerator = dGroupNode.getAmountOfSupplier();
  328. Object[] producer = { "Producer:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  329. numerator = dGroupNode.getAmountOfConsumerWithState(HolonObjectState.NOT_SUPPLIED);
  330. Object[] notSupplied = { "UnSupplied:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  331. numerator = dGroupNode.getAmountOfConsumerWithState(HolonObjectState.PARTIALLY_SUPPLIED);
  332. Object[] partiallySupplied = { "PartriallySupplied:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  333. numerator = dGroupNode.getAmountOfConsumerWithState(HolonObjectState.SUPPLIED);
  334. Object[] supplied = { "Supplied:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  335. numerator = dGroupNode.getAmountOfConsumerWithState(HolonObjectState.OVER_SUPPLIED);
  336. Object[] overSupplied = { "OverSupplied:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  337. numerator = dGroupNode.getAmountOfPassiv();
  338. Object[] passiv = { "Passiv(%):", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  339. Object[] nothing= {"", ""};
  340. numerator = dGroupNode.getAmountOfAktiveElemntsFromHolonObjects();
  341. denominator = dGroupNode.getAmountOfElemntsFromHolonObjects();
  342. Object[] aktiv = { "Active HolonElements:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  343. float consumption = dGroupNode.getConsumptionFromConsumer();
  344. float production = dGroupNode.getProductionFromSupplier();
  345. Object[] consumptionObj = { "Total Consumption:", consumption};
  346. Object[] productionObj = { "Total Production:", production};
  347. Object[] difference = { "Difference:", production - consumption};
  348. model.getPropertyTable().addRow(title);
  349. model.getPropertyTable().addRow(producer);
  350. model.getPropertyTable().addRow(notSupplied);
  351. model.getPropertyTable().addRow(partiallySupplied);
  352. model.getPropertyTable().addRow(supplied);
  353. model.getPropertyTable().addRow(overSupplied);
  354. model.getPropertyTable().addRow(passiv);
  355. model.getPropertyTable().addRow(nothing);
  356. model.getPropertyTable().addRow(aktiv);
  357. model.getPropertyTable().addRow(nothing);
  358. model.getPropertyTable().addRow(consumptionObj);
  359. model.getPropertyTable().addRow(productionObj);
  360. model.getPropertyTable().addRow(difference);
  361. }
  362. } else if (obj instanceof HolonBattery) {
  363. deleteRows(model.getSingleTable());
  364. deleteRows(model.getMultiTable());
  365. Object[] numInRatio = {"InRatio:", ((HolonBattery)obj).getInRatio() };
  366. Object[] numOutRatio = {"OutRatio:", ((HolonBattery)obj).getOutRatio() };
  367. Object[] numSOC_Capasity = {"State of charge:", Float.toString(((HolonBattery)obj).getStateOfChargeAtTimeStep(model.getCurIteration()-1)) + "/" + Float.toString(((HolonBattery)obj).getCapacity()) };
  368. model.getPropertyTable().addRow(numInRatio);
  369. model.getPropertyTable().addRow(numOutRatio);
  370. model.getPropertyTable().addRow(numSOC_Capasity);
  371. model.getPropertyTable().setCellEditable(0, 1, true);
  372. model.getPropertyTable().setCellEditable(2, 1, true);
  373. model.getPropertyTable().setCellEditable(3, 1, true);
  374. }else {
  375. deleteRows(model.getSingleTable());
  376. deleteRows(model.getMultiTable());
  377. }
  378. // For Objects the only editable cell is the name
  379. ArrayList<Edge> tempArray = obj.getConnections();
  380. // If the clicked object has connections
  381. if (!tempArray.isEmpty()) {
  382. boolean first = true;
  383. for (Edge temp2 : tempArray) {
  384. if (first) {
  385. first = false;
  386. if (obj.getId() != temp2.getA().getId()) {
  387. Object[] tempConnection = { obj.getName() + Languages.getLanguage()[76],
  388. temp2.getA().getName() + Languages.getLanguage()[77] + temp2.getA().getId() };
  389. model.getPropertyTable().addRow(tempConnection);
  390. } else {
  391. Object[] tempConnection = { obj.getName() + Languages.getLanguage()[76],
  392. temp2.getB().getName() + Languages.getLanguage()[77] + temp2.getB().getId() };
  393. model.getPropertyTable().addRow(tempConnection);
  394. }
  395. } else {
  396. if (obj.getId() != temp2.getA().getId()) {
  397. Object[] tempConnection = { "",
  398. temp2.getA().getName() + Languages.getLanguage()[77] + temp2.getA().getId() };
  399. model.getPropertyTable().addRow(tempConnection);
  400. } else {
  401. Object[] tempConnection = { "",
  402. temp2.getB().getName() + Languages.getLanguage()[77] + temp2.getB().getId() };
  403. model.getPropertyTable().addRow(tempConnection);
  404. }
  405. }
  406. }
  407. }
  408. } // If the clicked Object is an edge
  409. else if (model.getSelectedEdge() != null) {
  410. // Name displayed
  411. Object[] tempName = { Languages.getLanguage()[72],
  412. Languages.getLanguage()[78] + model.getSelectedEdge().getA().getName() + Languages.getLanguage()[79]
  413. + model.getSelectedEdge().getB().getName() };
  414. model.getPropertyTable().addRow(tempName);
  415. // Current Flow displayed
  416. Object[] tempFlow = { Languages.getLanguage()[80], "" };
  417. model.getPropertyTable().addRow(tempFlow);
  418. // Max Capacity displayed
  419. Object[] tempCapacity = { Languages.getLanguage()[81], model.getSelectedEdge().getCapacity() };
  420. model.getPropertyTable().addRow(tempCapacity);
  421. // Status displayed
  422. Object[] tempStatus = {"Length", model.getSelectedEdge().getLength() };
  423. model.getPropertyTable().addRow(tempStatus);
  424. // For edges, the only possible editable cell is the max
  425. // flow
  426. model.getPropertyTable().setCellEditable(0, 1, false);
  427. model.getPropertyTable().setCellEditable(2, 1, true);
  428. model.getPropertyTable().setCellEditable(3, 1, true);
  429. } else if (getActualCps() == null) {
  430. deleteRows(model.getSingleTable());
  431. deleteRows(model.getMultiTable());
  432. }
  433. // Update of the HolonElementTable (Single- or Multi-Selection)
  434. if (model.getSelectedCpsObjects().size() > 1) {
  435. model.getTableHolonElement().setModel(model.getMultiTable());
  436. } else if (model.getSelectedCpsObjects().size() == 1) {
  437. model.getTableHolonElement().setModel(model.getSingleTable());
  438. }
  439. }
  440. public AbstractCanvasObject getHolonObjSelected(int id) {
  441. AbstractCanvasObject obj = null;
  442. for (AbstractCanvasObject o : model.getSelectedCpsObjects()) {
  443. if (o.getId() == id) {
  444. obj = o;
  445. break;
  446. }
  447. }
  448. return obj;
  449. }
  450. /**
  451. *
  452. * @return id of column that should be sorted
  453. */
  454. public int getSortBy() {
  455. return sortBy;
  456. }
  457. /**
  458. * sets the column id that should be sorted
  459. * @param column
  460. */
  461. public void setSortBy(int column) {
  462. /**
  463. * if there is no "Object" column, assume coloumn 0 is
  464. */
  465. if(model.getTableHolonElement().getColumnCount()==7)
  466. this.sortBy = column+1;
  467. else
  468. this.sortBy = column;
  469. }
  470. }