UpdateController.java 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543
  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[] info = { "Statistics:", "" };
  318. Object[] numEle = { "Number of Objects (total)", ((CpsUpperNode) obj).getNodes().size() };
  319. Object[] numObj = { "Number of HolonObjects", ((CpsUpperNode) obj).getNumHolonObj().size() };
  320. Object[] numSwi = { "Number of HolonSwitches", ((CpsUpperNode) obj).getNumSwitches().size() };
  321. Object[] numUpp = { "Number of GroupNodes", ((CpsUpperNode) obj).getNumUpperNodes().size() };
  322. model.getPropertyTable().addRow(info);
  323. model.getPropertyTable().addRow(numEle);
  324. model.getPropertyTable().addRow(numObj);
  325. model.getPropertyTable().addRow(numSwi);
  326. model.getPropertyTable().addRow(numUpp);
  327. if(dGroupNode != null) {
  328. int numerator, denominator;
  329. Object[] title = { "HolonObject Statistics:", "" };
  330. denominator = dGroupNode.getAmountOfConsumer() + dGroupNode.getAmountOfSupplier() + dGroupNode.getAmountOfPassiv();
  331. numerator = dGroupNode.getAmountOfSupplier();
  332. Object[] producer = { "Producer:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  333. numerator = dGroupNode.getAmountOfConsumerWithState(HolonObjectState.NOT_SUPPLIED);
  334. Object[] notSupplied = { "UnSupplied:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  335. numerator = dGroupNode.getAmountOfConsumerWithState(HolonObjectState.PARTIALLY_SUPPLIED);
  336. Object[] partiallySupplied = { "PartriallySupplied:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  337. numerator = dGroupNode.getAmountOfConsumerWithState(HolonObjectState.SUPPLIED);
  338. Object[] supplied = { "Supplied:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  339. numerator = dGroupNode.getAmountOfConsumerWithState(HolonObjectState.OVER_SUPPLIED);
  340. Object[] overSupplied = { "OverSupplied:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  341. numerator = dGroupNode.getAmountOfPassiv();
  342. Object[] passiv = { "Passiv(%):", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  343. Object[] nothing= {"", ""};
  344. numerator = dGroupNode.getAmountOfAktiveElemntsFromHolonObjects();
  345. denominator = dGroupNode.getAmountOfElemntsFromHolonObjects();
  346. Object[] aktiv = { "Active HolonElements:", numerator + "/" + denominator + "("+ (float)numerator/(float)denominator * 100 + "%)"};
  347. float consumption = dGroupNode.getConsumptionFromConsumer();
  348. float production = dGroupNode.getProductionFromSupplier();
  349. Object[] consumptionObj = { "Total Consumption:", consumption};
  350. Object[] productionObj = { "Total Production:", production};
  351. Object[] difference = { "Difference:", Math.abs(consumption - production)};
  352. model.getPropertyTable().addRow(title);
  353. model.getPropertyTable().addRow(producer);
  354. model.getPropertyTable().addRow(notSupplied);
  355. model.getPropertyTable().addRow(partiallySupplied);
  356. model.getPropertyTable().addRow(supplied);
  357. model.getPropertyTable().addRow(overSupplied);
  358. model.getPropertyTable().addRow(passiv);
  359. model.getPropertyTable().addRow(nothing);
  360. model.getPropertyTable().addRow(aktiv);
  361. model.getPropertyTable().addRow(nothing);
  362. model.getPropertyTable().addRow(consumptionObj);
  363. model.getPropertyTable().addRow(productionObj);
  364. model.getPropertyTable().addRow(difference);
  365. }
  366. } else if (obj instanceof HolonBattery) {
  367. deleteRows(model.getSingleTable());
  368. deleteRows(model.getMultiTable());
  369. Object[] numInRatio = {"InRatio:", ((HolonBattery)obj).getInRatio() };
  370. Object[] numOutRatio = {"OutRatio:", ((HolonBattery)obj).getOutRatio() };
  371. Object[] numSOC_Capasity = {"State of charge:", Float.toString(((HolonBattery)obj).getStateOfChargeAtTimeStep(model.getCurIteration()-1)) + "/" + Float.toString(((HolonBattery)obj).getCapacity()) };
  372. model.getPropertyTable().addRow(numInRatio);
  373. model.getPropertyTable().addRow(numOutRatio);
  374. model.getPropertyTable().addRow(numSOC_Capasity);
  375. model.getPropertyTable().setCellEditable(0, 1, true);
  376. model.getPropertyTable().setCellEditable(2, 1, true);
  377. model.getPropertyTable().setCellEditable(3, 1, true);
  378. }else {
  379. deleteRows(model.getSingleTable());
  380. deleteRows(model.getMultiTable());
  381. }
  382. // For Objects the only editable cell is the name
  383. ArrayList<CpsEdge> tempArray = obj.getConnections();
  384. // If the clicked object has connections
  385. if (!tempArray.isEmpty()) {
  386. boolean first = true;
  387. for (CpsEdge temp2 : tempArray) {
  388. if (first) {
  389. first = false;
  390. if (obj.getId() != temp2.getA().getId()) {
  391. Object[] tempConnection = { obj.getName() + Languages.getLanguage()[76],
  392. temp2.getA().getName() + Languages.getLanguage()[77] + temp2.getA().getId() };
  393. model.getPropertyTable().addRow(tempConnection);
  394. } else {
  395. Object[] tempConnection = { obj.getName() + Languages.getLanguage()[76],
  396. temp2.getB().getName() + Languages.getLanguage()[77] + temp2.getB().getId() };
  397. model.getPropertyTable().addRow(tempConnection);
  398. }
  399. } else {
  400. if (obj.getId() != temp2.getA().getId()) {
  401. Object[] tempConnection = { "",
  402. temp2.getA().getName() + Languages.getLanguage()[77] + temp2.getA().getId() };
  403. model.getPropertyTable().addRow(tempConnection);
  404. } else {
  405. Object[] tempConnection = { "",
  406. temp2.getB().getName() + Languages.getLanguage()[77] + temp2.getB().getId() };
  407. model.getPropertyTable().addRow(tempConnection);
  408. }
  409. }
  410. }
  411. }
  412. } // If the clicked Object is an edge
  413. else if (model.getSelectedEdge() != null) {
  414. // Name displayed
  415. Object[] tempName = { Languages.getLanguage()[72],
  416. Languages.getLanguage()[78] + model.getSelectedEdge().getA().getName() + Languages.getLanguage()[79]
  417. + model.getSelectedEdge().getB().getName() };
  418. model.getPropertyTable().addRow(tempName);
  419. // Current Flow displayed
  420. Object[] tempFlow = { Languages.getLanguage()[80], "" };
  421. model.getPropertyTable().addRow(tempFlow);
  422. // Max Capacity displayed
  423. Object[] tempCapacity = { Languages.getLanguage()[81], model.getSelectedEdge().getCapacity() };
  424. model.getPropertyTable().addRow(tempCapacity);
  425. // Status displayed
  426. Object[] tempStatus = {Languages.getLanguage()[82], ""};
  427. model.getPropertyTable().addRow(tempStatus);
  428. // For edges, the only possible editable cell is the max
  429. // flow
  430. model.getPropertyTable().setCellEditable(0, 1, false);
  431. model.getPropertyTable().setCellEditable(2, 1, true);
  432. model.getPropertyTable().setCellEditable(3, 1, true);
  433. } else if (getActualCps() == null) {
  434. deleteRows(model.getSingleTable());
  435. deleteRows(model.getMultiTable());
  436. }
  437. // Update of the HolonElementTable (Single- or Multi-Selection)
  438. if (model.getSelectedCpsObjects().size() > 1) {
  439. model.getTableHolonElement().setModel(model.getMultiTable());
  440. } else if (model.getSelectedCpsObjects().size() == 1) {
  441. model.getTableHolonElement().setModel(model.getSingleTable());
  442. }
  443. }
  444. public AbstractCpsObject getHolonObjSelected(int id) {
  445. AbstractCpsObject obj = null;
  446. for (AbstractCpsObject o : model.getSelectedCpsObjects()) {
  447. if (o.getId() == id) {
  448. obj = o;
  449. break;
  450. }
  451. }
  452. return obj;
  453. }
  454. /**
  455. * fills the table when HolonCanvas is open
  456. *
  457. * @param id
  458. * ID of the selected HolonBody
  459. */
  460. public void paintHolonBody(int id) {
  461. if (id != -1) {
  462. ArrayList<SubNet> subs = controller.getSimManager().getSubNets();
  463. if (!subs.isEmpty()) {
  464. SubNet sub = subs.get(id);
  465. Object[] tempId = { "ID", id };
  466. model.getPropertyTable().addRow(tempId);
  467. Object[] tempObj = { "Nr. of Objects", sub.getObjects().size() };
  468. model.getPropertyTable().addRow(tempObj);
  469. Object[] tempEdg = { "Nr. of Edges", sub.getEdges().size() };
  470. model.getPropertyTable().addRow(tempEdg);
  471. Object[] tempSwi = { "Nr. of Switches", sub.getSwitches().size() };
  472. model.getPropertyTable().addRow(tempSwi);
  473. Object[] tempProd = { "Total Production",
  474. "" + controller.getTotalProduction(new ArrayList<AbstractCpsObject>(sub.getObjects())) };
  475. model.getPropertyTable().addRow(tempProd);
  476. Object[] tempCons = { "Total Consumption",
  477. "" + controller.getTotalConsumption(new ArrayList<AbstractCpsObject>(sub.getObjects())) };
  478. model.getPropertyTable().addRow(tempCons);
  479. Object[] tempEle = { "Nr. of Elements",
  480. "" + controller.getTotalElements(new ArrayList<AbstractCpsObject>(sub.getObjects())) };
  481. model.getPropertyTable().addRow(tempEle);
  482. Object[] tempProds = { "Nr. of Producers",
  483. "" + controller.getTotalProducers(new ArrayList<AbstractCpsObject>(sub.getObjects())) };
  484. model.getPropertyTable().addRow(tempProds);
  485. Object[] tempAct = { "Nr. of active Elements",
  486. "" + controller.getActiveElements(new ArrayList<AbstractCpsObject>(sub.getObjects())) };
  487. model.getPropertyTable().addRow(tempAct);
  488. }
  489. }
  490. }
  491. /**
  492. *
  493. * @return id of column that should be sorted
  494. */
  495. public int getSortBy() {
  496. return sortBy;
  497. }
  498. /**
  499. * sets the column id that should be sorted
  500. * @param column
  501. */
  502. public void setSortBy(int column) {
  503. /**
  504. * if there is no "Object" column, assume coloumn 0 is
  505. */
  506. if(model.getTableHolonElement().getColumnCount()==7)
  507. this.sortBy = column+1;
  508. else
  509. this.sortBy = column;
  510. }
  511. }