UpdateController.java 21 KB

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