GUI.java 99 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017
  1. package ui.view;
  2. import classes.*;
  3. import com.google.gson.JsonNull;
  4. import com.google.gson.JsonObject;
  5. import com.google.gson.JsonParseException;
  6. import interfaces.CategoryListener;
  7. import org.apache.commons.compress.archivers.ArchiveException;
  8. import ui.controller.Control;
  9. import ui.controller.SimulationManager;
  10. import ui.controller.UpdateController;
  11. import ui.model.Model;
  12. import javax.swing.*;
  13. import javax.swing.border.LineBorder;
  14. import javax.swing.filechooser.FileNameExtensionFilter;
  15. import javax.swing.table.DefaultTableModel;
  16. import javax.swing.table.JTableHeader;
  17. import javax.swing.table.TableCellEditor;
  18. import javax.swing.table.TableCellRenderer;
  19. import javax.swing.tree.DefaultMutableTreeNode;
  20. import javax.swing.tree.DefaultTreeModel;
  21. import javax.swing.tree.TreeCellRenderer;
  22. import java.awt.*;
  23. import java.awt.datatransfer.UnsupportedFlavorException;
  24. import java.awt.event.*;
  25. import java.io.File;
  26. import java.io.IOException;
  27. import java.net.URI;
  28. import java.net.URISyntaxException;
  29. import java.util.ArrayList;
  30. import java.util.List;
  31. import java.util.Timer;
  32. import java.util.TimerTask;
  33. import java.util.stream.Collectors;
  34. /**
  35. * Graphical User Interface.
  36. *
  37. * @author Gruppe14
  38. */
  39. public class GUI implements CategoryListener {
  40. /**
  41. * Menu on the Top containing File, Edit View Help etc
  42. */
  43. private final JMenuBar menuBar = new JMenuBar();
  44. private final JMenu mnNewMenu = new JMenu("File");
  45. private final JMenu mnNewMenuEdit = new JMenu("Edit");
  46. private final JMenu mnNewMenuOptions = new JMenu("Options");
  47. private final JMenu mnNewMenuView = new JMenu("View");
  48. private final AlgorithmMenu algorithmMenu;
  49. /** Help Menu containing helpful Informations and the AboutUs Popup */
  50. private final JMenu mnHelp = new JMenu("Help");
  51. /**
  52. * Help -> Introduction
  53. * A small Introduction of the Application, SmartGrids and Holons
  54. */
  55. private final JMenuItem mntmIntroduction = new JMenuItem("Introduction");
  56. /**
  57. * Help -> UserManual
  58. */
  59. private final JMenuItem mntmUserManual = new JMenuItem("User Manual");
  60. /** Help -> Algorithm Help Menu */
  61. private final JMenuItem mntmAlgorithmHelp = new JMenuItem("Algorithm Introduction");
  62. /** Help -> CodeDocumentation */
  63. private final JMenuItem mntmCodeDoc = new JMenuItem("Code Documentation");
  64. /** Help -> AboutUs */
  65. private final JMenuItem mntmAboutUs = new JMenuItem("About Us");
  66. private final JCheckBox consoleLogCheckBox = new JCheckBox(
  67. "Show program console log");
  68. private final JCheckBox useFlexibleDevicesCheckBox = new JCheckBox(
  69. "Automatically use flexible devices");
  70. /** checked if supplyBars should be shown */
  71. private final JCheckBox showSupplyBarsCheckBox = new JCheckBox(
  72. "Show supply bars.");
  73. /** menu for the different fairness Models */
  74. private final JMenu mnFairnessModel = new JMenu("Fairness Model");
  75. /** press to supply minimum demand first */
  76. private final JMenuItem mntmFairMinFirst = new JMenuItem(
  77. "Minimum demand first");
  78. /** press to give everyone the same energy */
  79. private final JMenuItem mntmFairAlleEqual = new JMenuItem(
  80. "Equal supply for everyone");
  81. private final JMenuItem mntmOpen = new JMenuItem("Open");
  82. private final JMenuItem mntmNew = new JMenuItem("New");
  83. private final JMenuItem mntmSave = new JMenuItem("Save");
  84. private final JMenuItem mntmCanvasSize = new JMenuItem("View Size");
  85. private final JMenuItem mntmBackground = new JMenuItem("Background Image");
  86. private final JMenuItem mntmSplitView = new JMenuItem("Split View");
  87. private final JSplitPane splitPane = new JSplitPane();
  88. private final JSplitPane splitPane1 = new JSplitPane();
  89. private final JSplitPane splitPaneCanvasConsole = new JSplitPane(
  90. JSplitPane.VERTICAL_SPLIT);
  91. // the tabbed canvas containing the different sub-net tabs of the grid (Main
  92. // Grid + Nodes of Nodes)
  93. private final JTabbedPane tabbedPaneInnerOriginal = new JTabbedPane(
  94. JTabbedPane.TOP);
  95. // the main canvas where we can see the grid currently displayed
  96. private final JScrollPane canvasSP = new JScrollPane();
  97. private final JScrollPane scrollPane1 = new JScrollPane();
  98. // private final JScrollPane holonSP = new JScrollPane();
  99. // the original tabbed Pane (containing tabs for view, statistics, holon,
  100. // flexibility)
  101. private final JTabbedPane tabbedPaneOriginal = new JTabbedPane(
  102. JTabbedPane.TOP);
  103. // the same tabbed Pane that appears once the view is split
  104. private final JTabbedPane tabbedPaneSplit = new JTabbedPane(JTabbedPane.TOP);
  105. private final JPopupMenu popmenuEdit = new JPopupMenu();
  106. private final JMenuItem editItem = new JMenuItem("Edit Object");
  107. private final StatisticPanel statSplitPane;
  108. private final JScrollPane statScrollPane;
  109. private final JLabel maxGraph = new JLabel("100%");
  110. private final JLabel medGraph = new JLabel("50%");
  111. private final JLabel minGraph = new JLabel("0%");
  112. private final JLabel elementGraph = new JLabel("None ");
  113. private final JLabel unitGraphLocalPeriodLbl = new JLabel("Local Period:");
  114. private final ArrayList<HolonElement> selectedElements = new ArrayList<>();
  115. private final JTree tree = new JTree();
  116. /******************************************
  117. ************* Right Container*************
  118. ******************************************
  119. * Right Container: here comes the information about the HolonObject, such
  120. * as HolonElements Information, Properties and Consumption/Production
  121. * graph.
  122. **/
  123. private final JSplitPane splitHolonElPro = new JSplitPane(
  124. JSplitPane.VERTICAL_SPLIT);
  125. private final JSplitPane splitGraphHolonEl = new JSplitPane(
  126. JSplitPane.VERTICAL_SPLIT);
  127. private final int distanceBetweenElementsAndGraph = 350;
  128. // Model for single or multi selection
  129. private final JPanel scrollElements = new JPanel();
  130. private final JScrollPane tableHolonElementScrollPane = new JScrollPane();
  131. // In this section are all the properties that correspond to the clicked
  132. // HolonObject, such as connections, name, Type, etc.
  133. // Table for Properties --> Cell with (0,1) is editable by CpsObjt and
  134. // Cell(3,1) is editable by Edges
  135. private final JTable tableProperties = new JTable() {
  136. private static final long serialVersionUID = 1L;
  137. @Override
  138. public TableCellRenderer getCellRenderer(int row, int column) {
  139. if (getValueAt(row, column) instanceof Boolean) {
  140. return super.getDefaultRenderer(Boolean.class);
  141. } else {
  142. return super.getCellRenderer(row, column);
  143. }
  144. }
  145. @Override
  146. public TableCellEditor getCellEditor(int row, int column) {
  147. if (getValueAt(row, column) instanceof Boolean) {
  148. return super.getDefaultEditor(Boolean.class);
  149. } else {
  150. return super.getCellEditor(row, column);
  151. }
  152. }
  153. };
  154. private final JPanel graphLabel = new JPanel();
  155. private final JScrollPane scrollProperties = new JScrollPane();
  156. // In this section is the graph for the selected HolonElement of the clicked
  157. // HolonObject
  158. private final JTable tableGraph = new JTable();
  159. private final DefaultTableModel tableModelGraph = new DefaultTableModel();
  160. private final JScrollPane scrollGraph = new JScrollPane();
  161. private final Model model;
  162. private final Control controller;
  163. // In this section are all the Holonelements that correspond to the clicked
  164. // HolonObject with consumption/production, name and amount.
  165. private final JPanel panel = new JPanel();
  166. private final JPanel panelHolonEl = new JPanel();
  167. private final JComboBox comboBox = new JComboBox();
  168. // Buttons
  169. private final JButton btnAdd = new JButton("New");
  170. private final JButton btnDel = new JButton("Delete");
  171. private final JButton btnAddHolEL = new JButton("New");
  172. private final JButton btnDelHolEL = new JButton("Delete");
  173. private final JButton resetGraphBtn = new JButton("Reset");
  174. private final JToolBar toolBar = new JToolBar();
  175. private final JToolBar toolBarHolonEl = new JToolBar();
  176. private final JToolBar toolBarGraph = new JToolBar();
  177. // Languages
  178. private final JMenuItem englishBtn = new JMenuItem("EN");
  179. private final JMenuItem spanishBtn = new JMenuItem("ES");
  180. private final JMenuItem germanBtn = new JMenuItem("DE");
  181. private final JMenuItem czechBtn = new JMenuItem("CZ");
  182. private final JMenuItem chineseBtn = new JMenuItem("ZH");
  183. // private final JComboBox comboBoxGraph = new JComboBox();
  184. private final Console console = new Console();
  185. private final MyCanvas canvas;
  186. private final HolonCanvas holonCanvas;
  187. private final UnitGraph unitGraph;
  188. /** Textfield to show the period of an element */
  189. private final JTextField unitGraphLocalPeriod = new JTextField();
  190. private final JCheckBox unitGraphStretchMode=new JCheckBox();
  191. private final JLabel unitGraphStretchModeLbl=new JLabel(" Use global");//Some padding
  192. private final JSplitPane splitPane3 = new JSplitPane();
  193. private final JSlider sizeSlider = new JSlider();
  194. private final JLabel lblImageSize = new JLabel(Languages.getLanguage()[94]);
  195. private final JMenuItem mntmUndo = new JMenuItem("Undo");
  196. private final JMenuItem mntmRedo = new JMenuItem("Redo");
  197. private final JMenuItem mntmEditEdges = new JMenuItem("Edge Properties");
  198. private final JMenuItem mntmFindReplace = new JMenuItem("Find/ Replace");
  199. private final JMenuItem mntmAlignAll = new JMenuItem("Align All");
  200. private final JMenuItem mntmEditShowedInformation = new JMenuItem(
  201. "Edit showed Information");
  202. private final JMenuItem mntmResetCategory = new JMenuItem(
  203. "Reset Categories");
  204. private final JMenu mnLanguage = new JMenu("Language");
  205. private final String[] columnNamesMulti = { "Object", "Nr.", "Device",
  206. "Energy", "Flexible Energy Available", "Quantity", "Activated",
  207. "Flexible" };
  208. private final String[] columnNamesSingle = { "Nr.", "Device", "Energy",
  209. "Flexible Energy Available", "Quantity", "Activated", "Flexible" };
  210. private final ArrayList<PropertyTable> tables = new ArrayList<>();
  211. private final String[] comboBoxCat = { "Category", "Object", "Switch", "Battery" };
  212. private final UpdateController updCon;
  213. private final JSplitPane splitPane_1 = new JSplitPane();
  214. private final JSlider holonBodySizeSlider = new JSlider();
  215. private final JLabel lblHolonBodySize = new JLabel("HolonBody SIze");
  216. private final JLabel lblSelectedElement = new JLabel("Selected Element: ");
  217. // for doubleclick
  218. private boolean click = false;
  219. private JFrame frmCyberPhysical;
  220. private JTabbedPane tabTemp; // tabbedPaneOriginal or tabbedPaneSplit
  221. private JSplitPane tempSplit;
  222. private boolean initSplit = true;
  223. private String catOfObjToBeEdited;
  224. private UpperNodeCanvas unc;
  225. private JPanel contentPane;
  226. private String holonEleNamesDisplayed = "None ";
  227. // Pop up Windows
  228. private AddObjectPopUp addObjectPopUP;
  229. private AboutUsPopUp aboutUsPopUp;
  230. private AddElementPopUp addElementPopUp;
  231. // variables
  232. private boolean dragging = false;
  233. private String actualObjectClicked;
  234. private Image img = null;
  235. private AbstractCpsObject tempCps = null;
  236. private int yValueElements = 0;
  237. // Time Stuff
  238. private TimePanel timePanel;
  239. // Coord for all Cells with text
  240. private int yThis;
  241. private int xThis;
  242. // Coord for all Cells with boolean values (checkbox)
  243. private int yBTis;
  244. private int xBThis;
  245. // Coord for the Edit-Modus in the PropertieTable
  246. private int yProThis;
  247. private int xProThis;
  248. private int yProThisOneClick;
  249. private int xProThisOneClick;
  250. private AbstractCpsObject temp = null;
  251. private String warningText = "Warning";
  252. private String saveBeforeNew = "Do you want to save your current data?";
  253. private String eraseCategory = "Do you really want to delete the Category ";
  254. private String selectObjBeforeErase = "Please select a Category or an Object in order to delete something.";
  255. /**
  256. * Create the application.
  257. *
  258. * @param control
  259. * the Controller
  260. */
  261. GUI(Control control) {
  262. this.controller = control;
  263. this.model = control.getModel();
  264. statSplitPane = new StatisticPanel(controller);
  265. model.addGraphListener(statSplitPane);
  266. model.setStatPanel(statSplitPane);
  267. statScrollPane = new JScrollPane(statSplitPane);
  268. this.unitGraph = new UnitGraph(model, control);
  269. this.canvas = new MyCanvas(model, control, unitGraph);
  270. this.holonCanvas = new HolonCanvas(model, control);
  271. control.initListener(this);
  272. controller.setCanvas(canvas);
  273. model.setConsole(console);
  274. algorithmMenu = new AlgorithmMenu(model, control, this);
  275. initialize();
  276. updateCategories(model.getCategories());
  277. updCon = new UpdateController(model, controller);
  278. }
  279. // /**
  280. // * Adds a Popup.
  281. // *
  282. // * @param component Component
  283. // * @param popup PopupMenu
  284. // */
  285. // private static void addPopup(Component component, final JPopupMenu popup)
  286. // {
  287. // component.addMouseListener(new MouseAdapter() {
  288. // public void mousePressed(MouseEvent e) {
  289. // if (e.isPopupTrigger()) {
  290. // showMenu(e);
  291. // }
  292. // }
  293. //
  294. // public void mouseReleased(MouseEvent e) {
  295. // if (e.isPopupTrigger()) {
  296. // showMenu(e);
  297. // }
  298. // }
  299. //
  300. // private void showMenu(MouseEvent e) {
  301. // popup.show(e.getComponent(), e.getX(), e.getY());
  302. // }
  303. //
  304. // });
  305. // }
  306. /**
  307. * Initialize the contents of the frame.
  308. */
  309. @SuppressWarnings({ "serial", "unchecked" })
  310. private void initialize() {
  311. frmCyberPhysical = new JFrame();
  312. frmCyberPhysical.setTitle("HOLEG Simulator");
  313. // try to restore old position/dimensions
  314. ArrayList<Integer> savedWindowDim = controller
  315. .loadSavedWindowDimensionsIfExistent();
  316. if (savedWindowDim.size() == 4) {
  317. frmCyberPhysical.setBounds(savedWindowDim.get(0),
  318. savedWindowDim.get(1), savedWindowDim.get(2),
  319. savedWindowDim.get(3));
  320. }
  321. // if the upper part of the window is showing, the windows can still be
  322. // moved,
  323. // but if it is not, we need to move it to somewhere else
  324. if (savedWindowDim.size() != 4 || !isUpperPanelInsideBounds()) {
  325. frmCyberPhysical.setBounds(100, 100, 1000, 800);
  326. frmCyberPhysical.setExtendedState(JFrame.MAXIMIZED_BOTH);
  327. }
  328. frmCyberPhysical.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);
  329. frmCyberPhysical.addWindowListener(new java.awt.event.WindowAdapter() {
  330. @Override
  331. public void windowClosing(java.awt.event.WindowEvent windowEvent) {
  332. if (JOptionPane.showConfirmDialog(frmCyberPhysical,
  333. Languages.getLanguage()[88],
  334. "Cyber Physical Systems Model",
  335. JOptionPane.YES_NO_OPTION, JOptionPane.QUESTION_MESSAGE) == JOptionPane.YES_OPTION) {
  336. controller.deleteDirectory(new File(System
  337. .getProperty("user.home")
  338. + "/.config/HolonGUI/Autosave"));
  339. // try to save the position and size of the window, such
  340. // that (if possible)
  341. // it can be opened in the same position the next time
  342. try {
  343. controller.savePosAndSizeOfWindow(
  344. frmCyberPhysical.getX(),
  345. frmCyberPhysical.getY(),
  346. frmCyberPhysical.getWidth(),
  347. frmCyberPhysical.getHeight());
  348. } catch (Exception e) {
  349. e.printStackTrace();
  350. }
  351. System.exit(0);
  352. }
  353. }
  354. });
  355. contentPane = (JPanel) frmCyberPhysical.getContentPane();
  356. int condition = JComponent.WHEN_IN_FOCUSED_WINDOW;
  357. InputMap inputMap = contentPane.getInputMap(condition);
  358. ActionMap actionMap = contentPane.getActionMap();
  359. String cntrlZDown = "controlZ";
  360. inputMap.put(KeyStroke.getKeyStroke("control Z"), cntrlZDown);
  361. actionMap.put(cntrlZDown, new AbstractAction() {
  362. private static final long serialVersionUID = 1L;
  363. @Override
  364. public void actionPerformed(ActionEvent e) {
  365. try {
  366. controller.loadAutoSave(controller.getUndoSave());
  367. canvas.repaint();
  368. unitGraph.update(model.getObjectsOnCanvas());
  369. updateUpperNodes();
  370. } catch (IOException eex) {
  371. eex.printStackTrace();
  372. }
  373. }
  374. });
  375. String cntrlYDown = "controlY";
  376. inputMap.put(KeyStroke.getKeyStroke("control Y"), cntrlYDown);
  377. actionMap.put(cntrlYDown, new AbstractAction() {
  378. private static final long serialVersionUID = 1L;
  379. @Override
  380. public void actionPerformed(ActionEvent e) {
  381. try {
  382. controller.loadAutoSave(controller.getRedoSave());
  383. canvas.repaint();
  384. unitGraph.update(model.getObjectsOnCanvas());
  385. updateUpperNodes();
  386. } catch (IOException ex) {
  387. ex.printStackTrace();
  388. }
  389. }
  390. });
  391. String cntrlADown = "controlA";
  392. inputMap.put(KeyStroke.getKeyStroke("control A"), cntrlADown);
  393. AbstractAction controlA = new AbstractAction() {
  394. private static final long serialVersionUID = 1L;
  395. @Override
  396. public void actionPerformed(ActionEvent e) {
  397. chooseTabTemp();
  398. model.getSelectedCpsObjects().clear();
  399. // Uppernode Canvas?
  400. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  401. Component canvasOrUpperNodeCanvas = scrollPane.getViewport()
  402. .getComponent(0);
  403. if (canvasOrUpperNodeCanvas instanceof UpperNodeCanvas) {
  404. UpperNodeCanvas uNC = (UpperNodeCanvas) canvasOrUpperNodeCanvas;
  405. for (AbstractCpsObject cps : uNC.upperNode.getNodes()) {
  406. controller.addSelectedObject(cps);
  407. }
  408. uNC.repaint();
  409. // or Canvas?
  410. } else if (canvasOrUpperNodeCanvas instanceof MyCanvas) {
  411. for (AbstractCpsObject cps : model.getObjectsOnCanvas()) {
  412. controller.addSelectedObject(cps);
  413. }
  414. canvas.repaint();
  415. }
  416. controller.getObjectsInDepth();
  417. }
  418. };
  419. actionMap.put(cntrlADown, controlA);
  420. String delDown = "delete";
  421. inputMap.put(KeyStroke.getKeyStroke(KeyEvent.VK_DELETE, 0, false),
  422. delDown);
  423. actionMap.put(delDown, new AbstractAction() {
  424. private static final long serialVersionUID = 1L;
  425. @Override
  426. public void actionPerformed(ActionEvent e) {
  427. chooseTabTemp();
  428. // Uppernode Canvas?
  429. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  430. Component canvasOrUpperNodeCanvas = scrollPane.getViewport()
  431. .getComponent(0);
  432. // check whether a producer was deleted (this triggers a
  433. // complete re-evaluation of the net)
  434. boolean wasProducerDeleted = false;
  435. if (canvasOrUpperNodeCanvas instanceof UpperNodeCanvas) {
  436. UpperNodeCanvas uNC = (UpperNodeCanvas) canvasOrUpperNodeCanvas;
  437. for (AbstractCpsObject cps : model.getSelectedCpsObjects()) {
  438. if (cps instanceof HolonObject
  439. && ((HolonObject) cps).getState() == HolonObject.PRODUCER) {
  440. wasProducerDeleted = true;
  441. }
  442. controller.removeTrackingObj(cps);
  443. if (uNC.upperNode.getNodes().contains(cps)) {
  444. controller.delObjUpperNode(cps, uNC.upperNode);
  445. unc.setToolTip(false);
  446. // remove UpperNodeTab if UpperNode deleted
  447. removeUpperNodeTab(cps);
  448. }
  449. }
  450. uNC.repaint();
  451. // or Canvas?
  452. } else if (canvasOrUpperNodeCanvas instanceof MyCanvas) {
  453. boolean save = false;
  454. // Edge Deleting
  455. CpsEdge edgeHighlight = model.getSelectedEdge();
  456. if (edgeHighlight != null) {
  457. controller.removeEdgesOnCanvas(edgeHighlight);
  458. // Look for a CPSNode with no Connections and delete
  459. // them
  460. if (edgeHighlight.getA().getClass() == CpsNode.class
  461. && edgeHighlight.getA().getConnections().size() == 0) {
  462. controller.delCanvasObject(edgeHighlight.getA(),
  463. false);
  464. }
  465. if (edgeHighlight.getB().getClass() == CpsNode.class
  466. && edgeHighlight.getB().getConnections().size() == 0) { // Look
  467. // on
  468. // the
  469. // other
  470. // end
  471. // of
  472. // the
  473. // cable
  474. controller.delCanvasObject(edgeHighlight.getB(),
  475. false);
  476. }
  477. ((MyCanvas) canvasOrUpperNodeCanvas).edgeHighlight = null;
  478. }
  479. for (int j = 0; j < model.getSelectedCpsObjects().size(); j++) {
  480. AbstractCpsObject cps = model.getSelectedCpsObjects()
  481. .get(j);
  482. if (cps instanceof HolonObject
  483. && ((HolonObject) cps).getState() == HolonObject.PRODUCER) {
  484. wasProducerDeleted = true;
  485. }
  486. controller.removeTrackingObj(cps);
  487. if (j < model.getSelectedCpsObjects().size() - 1)
  488. save = true;
  489. controller.delCanvasObject(cps, save);
  490. canvas.setToolTip(false);
  491. // remove UpperNodeTab if UpperNode deleted
  492. removeUpperNodeTab(cps);
  493. }
  494. canvas.repaint();
  495. }
  496. // recalculate net if a producer was deleted
  497. if (wasProducerDeleted) {
  498. controller.resetSimulation();
  499. controller.calculateStateForCurrentTimeStep();
  500. }
  501. model.getSelectedCpsObjects().clear();
  502. hideScrollGraph();
  503. }
  504. });
  505. String cntrlFDown = "controlF";
  506. inputMap.put(KeyStroke.getKeyStroke("control F"), cntrlFDown);
  507. actionMap.put(cntrlFDown, new AbstractAction() {
  508. private static final long serialVersionUID = 1L;
  509. @Override
  510. public void actionPerformed(ActionEvent e) {
  511. SearchPopUp dialog = new SearchPopUp(controller, canvas,
  512. frmCyberPhysical);
  513. dialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
  514. dialog.setVisible(true);
  515. }
  516. });
  517. String cntrlCDown = "controlC";
  518. inputMap.put(KeyStroke.getKeyStroke("control C"), cntrlCDown);
  519. AbstractAction controlC = new AbstractAction() {
  520. private static final long serialVersionUID = 1L;
  521. @Override
  522. public void actionPerformed(ActionEvent e) {
  523. chooseTabTemp();
  524. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  525. if (!model.getSelectedCpsObjects().isEmpty()) {
  526. if (scrollPane.getViewport().getComponent(0) instanceof UpperNodeCanvas)
  527. controller.copy(((UpperNodeCanvas) scrollPane
  528. .getViewport().getComponent(0)).upperNode);
  529. else
  530. controller.copy(null);
  531. if (!model.getClipboradObjects().isEmpty()) {
  532. canvas.itemPaste.setEnabled(true);
  533. }
  534. }
  535. }
  536. };
  537. actionMap.put(cntrlCDown, controlC);
  538. String cntrlVDown = "controlV";
  539. inputMap.put(KeyStroke.getKeyStroke("control V"), cntrlVDown);
  540. AbstractAction controlV = new AbstractAction() {
  541. private static final long serialVersionUID = 1L;
  542. @Override
  543. public void actionPerformed(ActionEvent e) {
  544. try {
  545. tabTemp = null;
  546. if (tabbedPaneOriginal.getMousePosition() != null) {
  547. tabTemp = tabbedPaneOriginal;
  548. } else {
  549. if (!initSplit) {
  550. tabTemp = tabbedPaneSplit;
  551. }
  552. }
  553. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  554. Component canvasOrUpperNodeCanvas = scrollPane
  555. .getViewport().getComponent(0);
  556. if (tabTemp != null
  557. && canvasOrUpperNodeCanvas instanceof UpperNodeCanvas) {
  558. controller
  559. .paste(((UpperNodeCanvas) canvasOrUpperNodeCanvas).upperNode,
  560. canvasOrUpperNodeCanvas
  561. .getMousePosition());
  562. unitGraph.update(model.getSelectedCpsObjects());
  563. scrollPane.getViewport().getComponent(0).repaint();
  564. } else {
  565. controller.paste(null, canvas.getMousePosition());
  566. unitGraph.update(model.getSelectedCpsObjects());
  567. canvas.repaint();
  568. }
  569. } catch (HeadlessException | JsonParseException
  570. | UnsupportedFlavorException | IOException e1) {
  571. JLabel message = new JLabel(
  572. "The Clipboard information cannot be pasted into Application.");
  573. JOptionPane.showMessageDialog(frmCyberPhysical, message,
  574. "", JOptionPane.ERROR_MESSAGE);
  575. }
  576. }
  577. };
  578. actionMap.put(cntrlVDown, controlV);
  579. String cntrlXDown = "controlX";
  580. inputMap.put(KeyStroke.getKeyStroke("control X"), cntrlXDown);
  581. AbstractAction controlX = new AbstractAction() {
  582. private static final long serialVersionUID = 1L;
  583. @Override
  584. public void actionPerformed(ActionEvent e) {
  585. chooseTabTemp();
  586. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  587. if (!model.getSelectedCpsObjects().isEmpty()) {
  588. if (scrollPane.getViewport().getComponent(0) instanceof UpperNodeCanvas) {
  589. controller.cut(((UpperNodeCanvas) scrollPane
  590. .getViewport().getComponent(0)).upperNode);
  591. } else {
  592. controller.cut(null);
  593. }
  594. if (!model.getClipboradObjects().isEmpty()) {
  595. canvas.itemPaste.setEnabled(true);
  596. }
  597. canvas.repaint();
  598. }
  599. }
  600. };
  601. actionMap.put(cntrlXDown, controlX);
  602. frmCyberPhysical.setJMenuBar(menuBar);
  603. frmCyberPhysical.setIconImage(Util.loadImage(this,
  604. "/Images/Holeg.png", 30, 30));
  605. menuBar.add(mnNewMenu);
  606. mnNewMenu.add(mntmNew);
  607. mnNewMenu.add(mntmOpen);
  608. mnNewMenu.add(mntmSave);
  609. menuBar.add(mnNewMenuEdit);
  610. mnNewMenuEdit.add(mntmUndo);
  611. mnNewMenuEdit.add(mntmRedo);
  612. mnLanguage.add(englishBtn);
  613. englishBtn.setIcon(new ImageIcon(new ImageIcon(
  614. "res/Button_Images/FlagEN.png").getImage().getScaledInstance(
  615. 20, 20, java.awt.Image.SCALE_SMOOTH)));
  616. mnLanguage.add(spanishBtn);
  617. spanishBtn.setIcon(new ImageIcon(new ImageIcon(
  618. "res/Button_Images/FlagES.png").getImage().getScaledInstance(
  619. 20, 20, java.awt.Image.SCALE_SMOOTH)));
  620. mnLanguage.add(germanBtn);
  621. germanBtn.setIcon(new ImageIcon(new ImageIcon(
  622. "res/Button_Images/FlagDE.png").getImage().getScaledInstance(
  623. 20, 20, java.awt.Image.SCALE_SMOOTH)));
  624. // mnLanguage.add(czechBtn);
  625. // czechBtn.setIcon(new ImageIcon(new
  626. // ImageIcon("res/Button_Images/FlagCZ.png").getImage().getScaledInstance(20,
  627. // 20, java.awt.Image.SCALE_SMOOTH)));
  628. mnLanguage.add(chineseBtn);
  629. chineseBtn.setIcon(new ImageIcon(new ImageIcon(
  630. "res/Button_Images/FlagZH.png").getImage().getScaledInstance(
  631. 20, 20, java.awt.Image.SCALE_SMOOTH)));
  632. mntmFindReplace.addActionListener(actionEvent -> {
  633. try {
  634. SearchPopUp dialog = new SearchPopUp(controller, canvas,
  635. frmCyberPhysical);
  636. dialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
  637. dialog.setVisible(true);
  638. controller.getObjectsInDepth();
  639. } catch (Exception ex) {
  640. ex.printStackTrace();
  641. }
  642. });
  643. mnNewMenuEdit.add(mntmFindReplace);
  644. mntmEditShowedInformation
  645. .addActionListener(actionEvent -> {
  646. try {
  647. DisplayedInformationPopUp dialog = new DisplayedInformationPopUp(
  648. canvas, contentPane, controller,
  649. frmCyberPhysical);
  650. dialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
  651. dialog.setVisible(true);
  652. } catch (Exception ex) {
  653. ex.printStackTrace();
  654. }
  655. });
  656. mnNewMenuEdit.add(mntmEditShowedInformation);
  657. mnNewMenuEdit.add(mntmEditEdges);
  658. mntmEditEdges.addActionListener(actionEvent -> {
  659. EditEdgesPopUp edgePopUp = new EditEdgesPopUp(frmCyberPhysical);
  660. edgePopUp.setCanvas(canvas);
  661. edgePopUp.setController(controller);
  662. edgePopUp.setVisible(true);
  663. });
  664. //Edit -> Align All
  665. mnNewMenuEdit.add(mntmAlignAll);
  666. mntmAlignAll.addActionListener(actionEvent -> {
  667. // getScrollPaneFromTabbedPane().getViewport().getComponent(0) is always the active canvas
  668. AbstractCanvas activeCanvas = ((AbstractCanvas) getScrollPaneFromTabbedPane().getViewport().getComponent(0));
  669. if (activeCanvas != null) {
  670. activeCanvas.tryToAlignObjects();
  671. activeCanvas.repaint();
  672. }
  673. });
  674. menuBar.add(mnNewMenuOptions);
  675. mnNewMenuOptions.add(mntmResetCategory);
  676. mntmResetCategory.addActionListener(actionEvent -> {
  677. ArrayList<Category> cat = model.getCategories();
  678. try {
  679. while (!cat.isEmpty()) {
  680. controller.deleteCategory(cat.get(0).getName());
  681. }
  682. controller.resetCategorys();
  683. } catch (Exception e2) {
  684. }
  685. tree.repaint();
  686. });
  687. mnNewMenuOptions.add(consoleLogCheckBox);
  688. consoleLogCheckBox.setSelected(true);
  689. consoleLogCheckBox.addActionListener(arg0 -> controller
  690. .setShowConsoleLog(consoleLogCheckBox.isSelected()));
  691. mnNewMenuOptions.add(useFlexibleDevicesCheckBox);
  692. useFlexibleDevicesCheckBox.setSelected(true);
  693. useFlexibleDevicesCheckBox
  694. .addActionListener(actionEvent -> model
  695. .setUseFlexibleDevices(useFlexibleDevicesCheckBox
  696. .isSelected()));
  697. /**
  698. * Add Fairness Model Option to the option Menu
  699. */
  700. mnNewMenuOptions.add(mnFairnessModel);
  701. mnFairnessModel.add(mntmFairMinFirst);
  702. mntmFairMinFirst.setForeground(Color.BLUE);
  703. mntmFairMinFirst
  704. .setToolTipText("HolonObjects with the smallest mininum Demand will be partially supplied first.\n"
  705. + "After that as many HolonObjects as possible will get fully supplied.");
  706. mntmFairMinFirst
  707. .addActionListener(arg0 -> {
  708. controller
  709. .setFairnessModel(SimulationManager.fairnessMininumDemandFirst);
  710. mntmFairMinFirst.setForeground(Color.BLUE);
  711. mntmFairAlleEqual.setForeground(mnFairnessModel
  712. .getForeground());
  713. controller.calculateStateForCurrentTimeStep();
  714. // Update UpperNodes
  715. Component canvasOrUpperNodeCanvas = getScrollPaneFromTabbedPane()
  716. .getViewport().getComponent(0);
  717. if (canvasOrUpperNodeCanvas != null
  718. && canvasOrUpperNodeCanvas instanceof UpperNodeCanvas) {
  719. ((UpperNodeCanvas) canvasOrUpperNodeCanvas).repaint();
  720. }
  721. });
  722. mnFairnessModel.add(mntmFairAlleEqual);
  723. mntmFairAlleEqual
  724. .setToolTipText("HolonObjects will all get the same amount of energy.");
  725. mntmFairAlleEqual.addActionListener(arg0 -> {
  726. controller.setFairnessModel(SimulationManager.fairnessAllEqual);
  727. mntmFairAlleEqual.setForeground(Color.BLUE);
  728. mntmFairMinFirst.setForeground(mnFairnessModel.getForeground());
  729. controller.calculateStateForCurrentTimeStep();
  730. // Update UpperNodes
  731. Component canvasOrUpperNodeCanvas = getScrollPaneFromTabbedPane()
  732. .getViewport().getComponent(0);
  733. if (canvasOrUpperNodeCanvas != null
  734. && canvasOrUpperNodeCanvas instanceof UpperNodeCanvas) {
  735. ((UpperNodeCanvas) canvasOrUpperNodeCanvas).repaint();
  736. }
  737. });
  738. menuBar.add(mnNewMenuView);
  739. mnNewMenuView.add(mntmCanvasSize);
  740. mntmCanvasSize.addActionListener(actionEvent -> {
  741. CanvasResizePopUp popUp = new CanvasResizePopUp(model, controller,
  742. canvas, tabbedPaneOriginal, tabbedPaneSplit,
  743. frmCyberPhysical);
  744. popUp.setVisible(true);
  745. });
  746. mnNewMenuView.add(splitPane3);
  747. sizeSlider.setMinimum(15);
  748. sizeSlider.setMaximum(115);
  749. sizeSlider
  750. .addChangeListener(changeEvent -> {
  751. controller.setScale(sizeSlider.getValue());
  752. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  753. if (scrollPane.getViewport().getComponent(0) instanceof UpperNodeCanvas) {
  754. scrollPane.getViewport().getComponent(0).repaint();
  755. } else {
  756. canvas.repaint();
  757. }
  758. if (!initSplit
  759. && scrollPane.getViewport().getComponent(0) instanceof UpperNodeCanvas) {
  760. scrollPane.getViewport().getComponent(0).repaint();
  761. } else {
  762. canvas.repaint();
  763. }
  764. });
  765. mnNewMenuView.add(mntmCanvasSize);
  766. mnNewMenuView.add(mntmSplitView);
  767. /*
  768. * Adds Checkbox to turn supply bars on/off
  769. */
  770. mnNewMenuView.add(showSupplyBarsCheckBox);
  771. showSupplyBarsCheckBox.setSelected(true);
  772. showSupplyBarsCheckBox.addActionListener(arg0 -> {
  773. controller.setShowSupplyBars(showSupplyBarsCheckBox.isSelected());
  774. canvas.repaint();
  775. // Update UpperNodes
  776. Component canvasOrUpperNodeCanvas = getScrollPaneFromTabbedPane()
  777. .getViewport().getComponent(0);
  778. if (canvasOrUpperNodeCanvas != null
  779. && canvasOrUpperNodeCanvas instanceof UpperNodeCanvas) {
  780. ((UpperNodeCanvas) canvasOrUpperNodeCanvas).repaint();
  781. }
  782. });
  783. // Split View
  784. mntmSplitView
  785. .addActionListener(actionEvent -> {
  786. if (splitPaneCanvasConsole.getLeftComponent() instanceof JSplitPane) {
  787. initSplit = true;
  788. Component tempC = tabbedPaneSplit
  789. .getSelectedComponent();
  790. tabbedPaneOriginal.setComponentAt(
  791. tabbedPaneSplit.getSelectedIndex(), tempC);
  792. tabbedPaneSplit.removeAll();
  793. splitPaneCanvasConsole
  794. .setLeftComponent(tabbedPaneOriginal);
  795. } else {
  796. for (int i = 0; i < tabbedPaneOriginal.getTabCount(); i++) {
  797. // add outer tabs
  798. // (inner tabs are added by tabbedPaneSplit
  799. // changelistener)
  800. tabbedPaneSplit.addTab(
  801. tabbedPaneOriginal.getTitleAt(i), null);
  802. }
  803. if (tabbedPaneOriginal.getSelectedComponent() == statScrollPane) {
  804. tabbedPaneOriginal.setComponentAt(0, null);
  805. tabbedPaneSplit.setComponentAt(0, canvasSP);
  806. tabbedPaneSplit.setSelectedIndex(0);
  807. } else {
  808. tabbedPaneOriginal.setComponentAt(1, null);
  809. tabbedPaneSplit.setComponentAt(1, statScrollPane);
  810. tabbedPaneSplit.setSelectedIndex(1);
  811. }
  812. tempSplit = new JSplitPane();
  813. tempSplit.setBorder(null);
  814. tempSplit.setRightComponent(tabbedPaneSplit);
  815. tempSplit.setLeftComponent(tabbedPaneOriginal);
  816. tempSplit.setDividerLocation(tabbedPaneOriginal
  817. .getWidth() / 2);
  818. tempSplit.setResizeWeight(0.9);
  819. splitPaneCanvasConsole.setLeftComponent(tempSplit);
  820. initSplit = false;
  821. }
  822. contentPane.updateUI();
  823. });
  824. mnNewMenuView.add(mntmBackground);
  825. mntmBackground
  826. .addActionListener(actionEvent -> {
  827. tabTemp = tabbedPaneOriginal;
  828. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  829. if (scrollPane.getViewport().getComponent(0) instanceof MyCanvas) {
  830. BackgroundPopUp backgroundDialog = new BackgroundPopUp(
  831. model, controller, canvas, null,
  832. frmCyberPhysical);
  833. backgroundDialog
  834. .setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
  835. backgroundDialog.setVisible(true);
  836. } else if (scrollPane.getViewport().getComponent(0) instanceof UpperNodeCanvas) {
  837. UpperNodeCanvas uNodeCanvas = (UpperNodeCanvas) (scrollPane
  838. .getViewport().getComponent(0));
  839. BackgroundPopUp backgroundDialog = new BackgroundPopUp(
  840. model, controller, null, uNodeCanvas.upperNode,
  841. frmCyberPhysical);
  842. backgroundDialog
  843. .setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
  844. backgroundDialog.setVisible(true);
  845. uNodeCanvas.repaint();
  846. }
  847. });
  848. splitPane3.setRightComponent(sizeSlider);
  849. splitPane3.setLeftComponent(lblImageSize);
  850. mnNewMenuView.add(splitPane_1);
  851. holonBodySizeSlider.setValue(100);
  852. holonBodySizeSlider.setMinimum(1);
  853. holonBodySizeSlider.addChangeListener(changeEvent -> {
  854. controller.setHolonBodyScale(holonBodySizeSlider.getValue());
  855. tree.setRowHeight(50);
  856. canvas.repaint();
  857. });
  858. splitPane_1.setRightComponent(holonBodySizeSlider);
  859. splitPane_1.setLeftComponent(lblHolonBodySize);
  860. menuBar.add(algorithmMenu);
  861. /**
  862. * add Help Menu and its items
  863. */
  864. menuBar.add(mnHelp);
  865. mnHelp.add(mntmIntroduction);
  866. mnHelp.add(mntmUserManual);
  867. mnHelp.add(mntmAlgorithmHelp);
  868. mnHelp.add(mntmCodeDoc);
  869. mnHelp.add(mntmAboutUs);
  870. tabbedPaneOriginal.addChangeListener(changeEvent -> {
  871. if (tabbedPaneOriginal.getSelectedComponent() == null) {
  872. Component tempC = tabbedPaneSplit.getSelectedComponent();
  873. tabbedPaneSplit.setComponentAt(
  874. tabbedPaneOriginal.getSelectedIndex(), null);
  875. tabbedPaneOriginal.setComponentAt(
  876. tabbedPaneOriginal.getSelectedIndex(), tempC);
  877. tempC = tabbedPaneOriginal.getComponentAt((tabbedPaneOriginal
  878. .getSelectedIndex() + 1)
  879. % (tabbedPaneOriginal.getTabCount()));
  880. tabbedPaneOriginal.setComponentAt(
  881. (tabbedPaneOriginal.getSelectedIndex() + 1)
  882. % (tabbedPaneOriginal.getTabCount()), null);
  883. tabbedPaneSplit.setComponentAt(
  884. (tabbedPaneOriginal.getSelectedIndex() + 1)
  885. % (tabbedPaneOriginal.getTabCount()), tempC);
  886. tabbedPaneSplit.setSelectedIndex((tabbedPaneOriginal
  887. .getSelectedIndex() + 1)
  888. % (tabbedPaneOriginal.getTabCount()));
  889. contentPane.updateUI();
  890. }
  891. });
  892. tabbedPaneSplit.addChangeListener(changeEvent -> {
  893. if (tabbedPaneSplit.getSelectedComponent() == null && !initSplit) {
  894. Component tempC = tabbedPaneOriginal
  895. .getComponentAt(tabbedPaneSplit.getSelectedIndex());
  896. tabbedPaneOriginal.setComponentAt(
  897. tabbedPaneSplit.getSelectedIndex(), null);
  898. tabbedPaneSplit.setComponentAt(
  899. tabbedPaneSplit.getSelectedIndex(), tempC);
  900. for (int i = 0; i < tabbedPaneOriginal.getTabCount(); i++) {
  901. if (tabbedPaneSplit.getComponentAt(i) != null
  902. && tabbedPaneSplit.getComponentAt(i) != tempC) {
  903. tempC = tabbedPaneSplit.getComponentAt(i);
  904. tabbedPaneSplit.setComponentAt(i, null);
  905. tabbedPaneOriginal.setComponentAt(i, tempC);
  906. break;
  907. }
  908. }
  909. if (tabbedPaneOriginal.getSelectedIndex() == tabbedPaneSplit
  910. .getSelectedIndex()) {
  911. tabbedPaneOriginal.setSelectedIndex((tabbedPaneSplit
  912. .getSelectedIndex() + 1)
  913. % tabbedPaneOriginal.getTabCount());
  914. }
  915. contentPane.updateUI();
  916. }
  917. });
  918. mnNewMenuOptions.add(mnLanguage);
  919. canvas.setBackground(Color.WHITE);
  920. canvas.setPreferredSize(new Dimension(model.getCanvasX(), model
  921. .getCanvasY()));
  922. holonCanvas.setBackground(Color.WHITE);
  923. holonCanvas.setPreferredSize(new Dimension(model.getCanvasX(), model
  924. .getCanvasY()));
  925. /********************
  926. * RIGHT CONTAINER (INFORMATION)
  927. **********************/
  928. // Set up of the HolonElements section
  929. // Two different Models: Multi for multi-selection mode and Single for
  930. // single-selection mode (CPS-Object)
  931. model.getMultiTable().setColumnIdentifiers(columnNamesMulti);
  932. model.getSingleTable().setColumnIdentifiers(columnNamesSingle);
  933. model.getTableHolonElement().setBorder(null);
  934. model.getTableHolonElement().setFillsViewportHeight(true);
  935. model.getTableHolonElement().setCellSelectionEnabled(true);
  936. model.getTableHolonElement().setColumnSelectionAllowed(true);
  937. /*
  938. * Register Clicks on ColumNames for sorting:
  939. */
  940. model.getTableHolonElement().getTableHeader()
  941. .addMouseListener(new MouseAdapter() {
  942. public void mouseClicked(MouseEvent e) {
  943. //TODO: sort
  944. //clicked column
  945. int col = model.getTableHolonElement().columnAtPoint(
  946. e.getPoint());
  947. //insert column into UpdateController
  948. updCon.setSortBy(col);
  949. //refresh HolonElementTable
  950. updCon.refreshTableHolonElement(model.getMultiTable(), model.getSingleTable());
  951. }
  952. });
  953. model.getTableHolonElement().getTableHeader().setReorderingAllowed(false);
  954. tableHolonElementScrollPane.setViewportView(model
  955. .getTableHolonElement());
  956. scrollElements.setLayout(new BorderLayout(0, 0));
  957. scrollElements.add(panelHolonEl, BorderLayout.NORTH);
  958. scrollElements.add(tableHolonElementScrollPane);
  959. panelHolonEl.setLayout(new BoxLayout(panelHolonEl, BoxLayout.X_AXIS));
  960. toolBarHolonEl.add(btnAddHolEL);
  961. toolBarHolonEl.add(btnDelHolEL);
  962. toolBarHolonEl.setFloatable(false);
  963. panelHolonEl.add(toolBarHolonEl);
  964. // Set up of the Properties section
  965. tableProperties.setModel(model.getPropertyTable());
  966. tableProperties.setFillsViewportHeight(true);
  967. tableProperties.setCellSelectionEnabled(true);
  968. tableProperties.setColumnSelectionAllowed(true);
  969. scrollProperties.setViewportView(tableProperties);
  970. // Set up of the Graph section
  971. tableGraph.setModel(tableModelGraph);
  972. tableGraph.setFillsViewportHeight(true);
  973. tableGraph.setCellSelectionEnabled(true);
  974. tableGraph.setColumnSelectionAllowed(true);
  975. scrollGraph.setViewportView(unitGraph);
  976. graphLabel.setLayout(new BorderLayout(0, 10));
  977. graphLabel.add(maxGraph, BorderLayout.NORTH);
  978. graphLabel.add(medGraph, BorderLayout.CENTER);
  979. graphLabel.add(minGraph, BorderLayout.SOUTH);
  980. toolBarGraph.add(lblSelectedElement);
  981. toolBarGraph.add(elementGraph);
  982. Component horizontalStrut = Box.createHorizontalStrut(20);
  983. /*
  984. Component horizontalStrut = Box.createHorizontalStrut(toolBarGraph
  985. .getWidth() - resetGraphBtn.getWidth() - unitGraphLocalPeriod.getWidth()
  986. -unitGraphLocalPeriodLbl.getWidth());
  987. */
  988. toolBarGraph.add(horizontalStrut);//What is this for?
  989. /** Add local Graph length Textfield an Label */
  990. unitGraphLocalPeriod.setPreferredSize(new Dimension(30, 20));//TODO
  991. unitGraphLocalPeriod.setText(""+unitGraph.getLocalPeriod());
  992. resetGraphBtn.setHorizontalAlignment(SwingConstants.RIGHT);
  993. toolBarGraph.add(unitGraphLocalPeriodLbl);
  994. unitGraphLocalPeriodLbl.setHorizontalAlignment(SwingConstants.RIGHT);
  995. toolBarGraph.add(unitGraphLocalPeriod);
  996. resetGraphBtn.setHorizontalAlignment(SwingConstants.RIGHT);
  997. toolBarGraph.add(resetGraphBtn);
  998. toolBarGraph.add(unitGraphStretchModeLbl);
  999. unitGraphStretchModeLbl.setHorizontalAlignment(SwingConstants.RIGHT);
  1000. toolBarGraph.add(unitGraphStretchMode);
  1001. unitGraphStretchMode.setHorizontalAlignment(SwingConstants.RIGHT);
  1002. unitGraphStretchMode.addActionListener(e ->
  1003. {unitGraph.setStretching(unitGraphStretchMode.isSelected());}
  1004. );
  1005. toolBarGraph.setFloatable(false);
  1006. scrollGraph.setRowHeaderView(graphLabel);
  1007. scrollGraph.setColumnHeaderView(toolBarGraph);
  1008. tables.add(model.getSingleTable());
  1009. tables.add(model.getMultiTable());
  1010. /***********************
  1011. * HolonElement Table Actions
  1012. **********************/
  1013. /*
  1014. * Add HolonElement to given HolonObject
  1015. */
  1016. btnAddHolEL.addActionListener(actionEvent -> {
  1017. if (model.getSelectedCpsObjects().size() == 1) {
  1018. AbstractCpsObject tempCpsObject = updCon.getActualCps();
  1019. if (tempCpsObject != null
  1020. && tempCpsObject.getClass() == HolonObject.class
  1021. && tempCpsObject.getId() != 0) {
  1022. addElementPopUp = new AddElementPopUp(frmCyberPhysical, model);//TODO: I didn't even check
  1023. addElementPopUp.setActualCps(updCon.getActualCps());
  1024. addElementPopUp.setVisible(true);
  1025. HolonElement ele = addElementPopUp.getElement();
  1026. if (ele != null) {
  1027. controller.addElementCanvasObject(
  1028. tempCpsObject.getId(), ele.getEleName(),
  1029. ele.getAmount(), ele.getEnergyPerElement(),
  1030. ele.getId());
  1031. }
  1032. controller.calculateStateForTimeStep(model
  1033. .getCurIteration());
  1034. triggerUpdateController(null);
  1035. contentPane.updateUI();
  1036. }
  1037. }else
  1038. {
  1039. JOptionPane.showMessageDialog(contentPane, "No object selected.\nPlease select a object first." , "Message" , JOptionPane.INFORMATION_MESSAGE);
  1040. }
  1041. });
  1042. /*
  1043. * Delete the chosen HolonElement of the selected HolonObject,
  1044. * Multi-Selection for CpsObjects as well as for HolonElements possible
  1045. */
  1046. btnDelHolEL.addActionListener(actionEvent -> {
  1047. // For Single Selection of CpsObject
  1048. if (model.getSelectedCpsObjects().size() == 1) {
  1049. if (updCon.getActualCps().getClass() == HolonObject.class) {
  1050. HolonObject obj = (HolonObject) updCon.getActualCps();
  1051. if(selectedElements.isEmpty())
  1052. {
  1053. JOptionPane.showMessageDialog(contentPane, "No element selectet.\nPlease select a element in the list first." , "Message" , JOptionPane.INFORMATION_MESSAGE);
  1054. }
  1055. for (HolonElement e : selectedElements) {
  1056. controller.deleteElementCanvas(obj.getId(),
  1057. e.getId());
  1058. controller.calculateStateForTimeStep(model
  1059. .getCurIteration());
  1060. triggerUpdateController(null);
  1061. contentPane.updateUI();
  1062. // Names displayed in graph are not updated
  1063. }
  1064. model.getEleToDelete().clear();
  1065. selectedElements.clear();
  1066. }
  1067. // For MultiSelection of CpsObject
  1068. } else if (model.getSelectedCpsObjects().size() > 1) {
  1069. for (Integer i : model.getEleToDelete().keySet()) {
  1070. for (HolonElement e : model.getEleToDelete().get(i)) {
  1071. controller.deleteElementCanvas(i, e.getId());
  1072. }
  1073. }
  1074. triggerUpdateController(null);
  1075. model.getEleToDelete().clear();
  1076. selectedElements.clear();
  1077. }else
  1078. {
  1079. JOptionPane.showMessageDialog(contentPane, "No object selectet.\nPlease select a object first." , "No object selectet" , JOptionPane.INFORMATION_MESSAGE);
  1080. }
  1081. triggerUpdateController(null);
  1082. elementGraph.setText(Languages.getLanguage()[25]);
  1083. holonEleNamesDisplayed = Languages.getLanguage()[25];
  1084. }) ;
  1085. /*
  1086. * Communication between HolonElement Table and displayed Graph and
  1087. * Properties, as well as selection of different HolonElements
  1088. */
  1089. model.getTableHolonElement().addMouseListener(new MouseAdapter() {
  1090. public void mousePressed(MouseEvent e) {
  1091. HolonObject obj = null;
  1092. if (model.getSelectedCpsObjects().size() == 1
  1093. && model.getSelectedCpsObjects().get(0) instanceof HolonObject) {
  1094. obj = (HolonObject) updCon.getActualCps();
  1095. }
  1096. yValueElements = e.getY();
  1097. HolonElement ele;
  1098. // Search for current clicked HolonElement
  1099. if (model.getSelectedCpsObjects().size() == 1) {
  1100. ele = updCon.getActualHolonElement(obj, yValueElements, 0,
  1101. tables);
  1102. } else {
  1103. ele = updCon.getActualHolonElement(null, yValueElements, 0,
  1104. tables);
  1105. }
  1106. // Multi-Selection of HolonElements through control button +
  1107. // mouse click
  1108. if (ele != null) {
  1109. // make energy-consumption graph visible
  1110. showScrollGraph();
  1111. if (e.isControlDown()) {
  1112. if (!selectedElements.contains(ele)) {
  1113. selectedElements.add(ele);
  1114. if (!holonEleNamesDisplayed.equals(Languages
  1115. .getLanguage()[25])) {
  1116. holonEleNamesDisplayed = holonEleNamesDisplayed
  1117. + "; " + ele.getEleName() + " ";
  1118. } else {
  1119. holonEleNamesDisplayed = ele.getEleName() + " ";
  1120. }
  1121. repaintGraphAux(selectedElements);
  1122. }
  1123. updCon.getActualHolonElement(null, yValueElements, 2,
  1124. tables);
  1125. }
  1126. // if no control-button pressed but a HolonElement chosen
  1127. else {
  1128. selectedElements.clear();
  1129. selectedElements.add(ele);
  1130. updCon.getActualHolonElement(null, yValueElements, 1,
  1131. tables);
  1132. holonEleNamesDisplayed = ele.getEleName() + " ";
  1133. repaintGraphAux(selectedElements);
  1134. }
  1135. } else {
  1136. elementGraph.setText(Languages.getLanguage()[25]);
  1137. hideScrollGraph();
  1138. }
  1139. // if any HolonElement is double-clicked --> Edit-Mode started
  1140. // for selected HolonElement
  1141. if (e.getClickCount() == 2) {
  1142. yThis = e.getY();
  1143. xThis = e.getX();
  1144. }
  1145. // for single click and empty slot
  1146. if (e.getClickCount() == 1 && ele == null) {
  1147. selectedElements.clear();
  1148. holonEleNamesDisplayed = Languages.getLanguage()[25];
  1149. }
  1150. elementGraph.setText(holonEleNamesDisplayed);
  1151. yBTis = e.getY();
  1152. xBThis = e.getX();
  1153. }
  1154. });
  1155. /*
  1156. * Triggered every time a change is made
  1157. */
  1158. model.getTableHolonElement()
  1159. .addPropertyChangeListener(propertyChangeEvent -> {
  1160. try {
  1161. int yMouse = yThis;
  1162. int yBMouse = yBTis;
  1163. int selectedValueY = (int) Math.floor(yMouse / 16);
  1164. int selectedValueBY = (int) Math.floor(yBMouse / 16);
  1165. // ------------------ multi-selection mode
  1166. // ------------------
  1167. if (model.getSelectedCpsObjects().size() > 1) {
  1168. int selectedValueX = (int) Math
  1169. .floor(xThis
  1170. / (model.getTableHolonElement()
  1171. .getWidth() / 8));
  1172. int selectedValueBX = (int) Math
  1173. .floor(xBThis
  1174. / (model.getTableHolonElement()
  1175. .getWidth() / 8));
  1176. if (updCon.getHolonObj(yMouse,
  1177. model.getMultiTable()) != null) {
  1178. // For active column (boolean with a checkbox)
  1179. if (selectedValueBX == 6) {
  1180. HolonElement eleBTemp = updCon
  1181. .getActualHolonElement(null,
  1182. yBMouse, 0, tables);
  1183. String newBStuff = model
  1184. .getMultiTable()
  1185. .getValueAt(selectedValueBY,
  1186. selectedValueBX).toString();
  1187. Boolean bTemp = Boolean
  1188. .parseBoolean(newBStuff);
  1189. eleBTemp.setActive(bTemp);
  1190. }
  1191. // For activeFlex column (boolean with a
  1192. // checkbox)
  1193. else if (selectedValueBX == 7) {
  1194. HolonElement eleBTemp = updCon
  1195. .getActualHolonElement(null,
  1196. yBMouse, 0, tables);
  1197. String newBStuff = model
  1198. .getMultiTable()
  1199. .getValueAt(selectedValueBY,
  1200. selectedValueBX).toString();
  1201. Boolean bTemp = Boolean
  1202. .parseBoolean(newBStuff);
  1203. eleBTemp.setFlexible(bTemp);
  1204. } else {
  1205. // Update of HolonElement
  1206. HolonElement eleTemp = updCon
  1207. .getActualHolonElement(null,
  1208. yMouse, 0, tables);
  1209. String newStuff = model
  1210. .getMultiTable()
  1211. .getValueAt(selectedValueY,
  1212. selectedValueX).toString();
  1213. // Name update
  1214. if (selectedValueX == 2) {
  1215. eleTemp.setEleName(newStuff);
  1216. }
  1217. // Energy Update
  1218. else if (selectedValueX == 3) {
  1219. Float ftemp = Float
  1220. .parseFloat(newStuff);
  1221. eleTemp.setEnergyPerElement(ftemp);
  1222. }
  1223. // Flexibility
  1224. else if (selectedValueX == 4) {
  1225. Float ftemp = Float
  1226. .parseFloat(newStuff);
  1227. eleTemp.setFlexibleEnergyAvailable(ftemp);
  1228. }
  1229. // Amount of Elements update
  1230. else if (selectedValueX == 5) {
  1231. Integer iTemp = Integer
  1232. .parseInt(newStuff);
  1233. eleTemp.setAmount(iTemp);
  1234. }
  1235. }
  1236. }
  1237. } // ------------------ single-selection mode
  1238. // ------------------
  1239. else if (model.getSelectedCpsObjects().size() == 1) {
  1240. int selectedValueX = (int) Math
  1241. .floor(xThis
  1242. / (model.getTableHolonElement()
  1243. .getWidth() / 7));
  1244. int selectedValueBX = (int) Math
  1245. .floor(xBThis
  1246. / (model.getTableHolonElement()
  1247. .getWidth() / 7));
  1248. if (updCon.getActualCps() != null
  1249. && updCon.getActualCps().getClass() == HolonObject.class) {
  1250. HolonElement eleTemp;
  1251. // For active column (boolean with a checkbox)
  1252. if (selectedValueBX == 5) {
  1253. eleTemp = updCon.getActualHolonElement(
  1254. (HolonObject) updCon.getActualCps(),
  1255. yBMouse, 0, tables);
  1256. String newBStuff = model
  1257. .getSingleTable()
  1258. .getValueAt(selectedValueBY,
  1259. selectedValueBX).toString();
  1260. Boolean bTemp = Boolean
  1261. .parseBoolean(newBStuff);
  1262. eleTemp.setActive(bTemp);
  1263. } // For activeFlex column (boolean with a
  1264. // checkbox)
  1265. else if (selectedValueBX == 6) {
  1266. eleTemp = updCon.getActualHolonElement(
  1267. (HolonObject) updCon.getActualCps(),
  1268. yBMouse, 0, tables);
  1269. String newBStuff = model
  1270. .getSingleTable()
  1271. .getValueAt(selectedValueBY,
  1272. selectedValueBX).toString();
  1273. Boolean bTemp = Boolean
  1274. .parseBoolean(newBStuff);
  1275. eleTemp.setFlexible(bTemp);
  1276. } else {
  1277. // Update of HolonElement
  1278. eleTemp = updCon.getActualHolonElement(
  1279. (HolonObject) updCon.getActualCps(),
  1280. yMouse, 0, tables);
  1281. String newStuff = model
  1282. .getSingleTable()
  1283. .getValueAt(selectedValueY,
  1284. selectedValueX).toString();
  1285. // Name update
  1286. if (selectedValueX == 1) {
  1287. eleTemp.setEleName(newStuff);
  1288. } // Energy Update
  1289. else if (selectedValueX == 2) {
  1290. Float ftemp = Float
  1291. .parseFloat(newStuff);
  1292. eleTemp.setEnergyPerElement(ftemp);
  1293. } // Flexibility
  1294. else if (selectedValueX == 3) {
  1295. Float ftemp = Float
  1296. .parseFloat(newStuff);
  1297. eleTemp.setFlexibleEnergyAvailable(ftemp);
  1298. // if this is a flexible device and the
  1299. // flexibly available energy was
  1300. // changed,
  1301. // set used energy to 0, so that it can
  1302. // be computed anew
  1303. if (eleTemp.isFlexible()) {
  1304. eleTemp.setEnergyPerElement(0);
  1305. }
  1306. }
  1307. // Amount of Elements update
  1308. else if (selectedValueX == 4) {
  1309. Integer iTemp = Integer
  1310. .parseInt(newStuff);
  1311. eleTemp.setAmount(iTemp);
  1312. }
  1313. }
  1314. // set all cells anew, if anything was changed
  1315. updateElementTableAfterChange(eleTemp,
  1316. selectedValueBY);
  1317. }
  1318. }
  1319. controller.calculateStateForTimeStep(model
  1320. .getCurIteration());
  1321. model.getSingleTable().fireTableDataChanged();
  1322. triggerUpdateController(null);
  1323. contentPane.updateUI();
  1324. unitGraph.repaint();
  1325. // trigger update of table after UnitGraph was painted
  1326. SwingUtilities.invokeLater(() -> {
  1327. triggerUpdateController(null);
  1328. });
  1329. } catch (Exception e) {
  1330. }
  1331. });
  1332. /***********************
  1333. * HolonElement Properties Actions
  1334. **********************/
  1335. /*
  1336. * Update of the mouse coord for Edit-Mode
  1337. */
  1338. tableProperties.addMouseListener(new MouseAdapter() {
  1339. public void mousePressed(MouseEvent e) {
  1340. if (e.getClickCount() == 2) {
  1341. yProThis = e.getY();
  1342. xProThis = e.getX();
  1343. }
  1344. yProThisOneClick = e.getY();
  1345. xProThisOneClick = e.getX();
  1346. }
  1347. });
  1348. /*
  1349. * Update any change in the Property table
  1350. */
  1351. tableProperties.addPropertyChangeListener(propertyChangeEvent -> {
  1352. try {
  1353. Object temp;
  1354. Object btemp;
  1355. int selValueY = (int) Math.floor(yProThis / 16);
  1356. int selValueX = (int) Math.floor(xProThis
  1357. / (tableProperties.getWidth() / 2));
  1358. int selValueYBool = (int) Math.floor(yProThisOneClick / 16);
  1359. int selValueXBool = (int) Math.floor(xProThisOneClick
  1360. / (tableProperties.getWidth() / 2));
  1361. if (updCon.getActualCps() != null) {
  1362. temp = model.getPropertyTable().getValueAt(selValueY,
  1363. selValueX);
  1364. btemp = model.getPropertyTable().getValueAt(selValueYBool,
  1365. selValueXBool);
  1366. // Case: Switch selected
  1367. if (updCon.getActualCps() instanceof HolonSwitch) {
  1368. if (selValueY == 0 && selValueX != 0) {
  1369. updCon.getActualCps().setName(temp.toString());
  1370. }
  1371. if (selValueYBool == 2) {
  1372. Boolean bbTemp = Boolean.parseBoolean(btemp.toString());
  1373. ((HolonSwitch) updCon.getActualCps())
  1374. .setManualMode(bbTemp);
  1375. if (bbTemp) {
  1376. model.getPropertyTable()
  1377. .setCellEditable(3, 1, true);
  1378. } else {
  1379. model.getPropertyTable().setCellEditable(3, 1,
  1380. false);
  1381. }
  1382. } else if (selValueYBool == 3) {
  1383. if (((HolonSwitch) updCon.getActualCps())
  1384. .getManualMode()) {
  1385. model.getPropertyTable()
  1386. .setCellEditable(3, 1, true);
  1387. Boolean bTemp = Boolean.parseBoolean(btemp
  1388. .toString());
  1389. ((HolonSwitch) updCon.getActualCps())
  1390. .setManualState(bTemp);
  1391. }
  1392. }
  1393. } // Case: UpperNode selected
  1394. else if (updCon.getActualCps() instanceof CpsUpperNode
  1395. && selValueX != 0) {
  1396. // Name edition through double click
  1397. updCon.getActualCps().setName(temp.toString());
  1398. // Update of name on the tab in the tab section
  1399. for (int index = 4; index < tabbedPaneOriginal
  1400. .getTabCount(); index++) {
  1401. tabTemp = tabbedPaneOriginal;
  1402. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  1403. UpperNodeCanvas unc = ((UpperNodeCanvas) scrollPane
  1404. .getViewport().getComponent(0));
  1405. if (unc.upperNode.getId() == updCon.getActualCps()
  1406. .getId()) {
  1407. tabbedPaneOriginal.setTitleAt(index,
  1408. unc.upperNode.getName());
  1409. tabbedPaneOriginal.updateUI();
  1410. if (!initSplit) {
  1411. tabbedPaneSplit.setTitleAt(index,
  1412. unc.upperNode.getName());
  1413. tabbedPaneSplit.updateUI();
  1414. }
  1415. }
  1416. }
  1417. } // Case: HolonObject is selected
  1418. else if (updCon.getActualCps() instanceof HolonObject
  1419. && selValueX != 0) {
  1420. // Name edition through double click
  1421. updCon.getActualCps().setName(temp.toString());
  1422. }
  1423. } // Case: Edge is selected
  1424. else {
  1425. temp = model.getPropertyTable()
  1426. .getValueAt(selValueY, selValueX);
  1427. btemp = model.getPropertyTable().getValueAt(selValueYBool,
  1428. selValueXBool);
  1429. // Edit modus for capacity by double clicking
  1430. if (selValueY == 2) {
  1431. Float ftemp;
  1432. if (Float.parseFloat(temp.toString()) >= 0.0) {
  1433. ftemp = Float.parseFloat(temp.toString());
  1434. } else {
  1435. ftemp = model.getSelectedEdge().getCapacity();
  1436. }
  1437. model.getSelectedEdge().setCapacity(ftemp);
  1438. }
  1439. // Status edition through a check box
  1440. if (selValueYBool == 3) {
  1441. Boolean bbTemp = Boolean.parseBoolean(btemp.toString());
  1442. model.getSelectedEdge().setWorkingState(bbTemp);
  1443. }
  1444. }
  1445. canvas.repaint();
  1446. } catch (Exception e) {
  1447. }
  1448. }) ;
  1449. /***********************
  1450. * HolonElement Graph Actions
  1451. **********************/
  1452. /*
  1453. * Reset the graph of the selected HolonElement
  1454. */
  1455. resetGraphBtn.setBorder(new LineBorder(Color.BLACK));
  1456. resetGraphBtn.addActionListener(actionEvent -> unitGraph.reset());
  1457. /*
  1458. * Update Local Period of an Element Graph
  1459. */
  1460. unitGraphLocalPeriod.addKeyListener(new KeyAdapter() {
  1461. @Override
  1462. public void keyReleased(KeyEvent e) {
  1463. try{
  1464. int localLength = Integer.parseInt(unitGraphLocalPeriod.getText());
  1465. unitGraphLocalPeriod.setBackground(Color.WHITE);
  1466. /**
  1467. * set local graph Period
  1468. */
  1469. if(e.getKeyCode() == KeyEvent.VK_ENTER)
  1470. unitGraph.setLocalPeriod(localLength);
  1471. }catch(Exception ex){
  1472. unitGraphLocalPeriod.setBackground(Color.RED);
  1473. }
  1474. }
  1475. });
  1476. /*****************************
  1477. * RIGHT CONTAINER DONE
  1478. *****************************/
  1479. frmCyberPhysical.getContentPane().setLayout(new BorderLayout(0, 0));
  1480. /****************
  1481. * Tree Stuff
  1482. ****************/
  1483. // Override Key Actions
  1484. inputMap = tree.getInputMap();
  1485. inputMap.put(KeyStroke.getKeyStroke("control C"), cntrlCDown);
  1486. inputMap.put(KeyStroke.getKeyStroke("control V"), cntrlVDown);
  1487. inputMap.put(KeyStroke.getKeyStroke("control X"), cntrlXDown);
  1488. inputMap.put(KeyStroke.getKeyStroke("control A"), cntrlADown);
  1489. TreeCellRenderer customRenderer = new TreeCellRenderer() {
  1490. @Override
  1491. public Component getTreeCellRendererComponent(JTree tree,
  1492. Object value, boolean selected, boolean expanded,
  1493. boolean leaf, int row, boolean hasFocus) {
  1494. JLabel label = new JLabel();
  1495. Image imgR;
  1496. if (leaf) {
  1497. for (Category cat : model.getCategories()) {
  1498. for (AbstractCpsObject cps : cat.getObjects()) {
  1499. if (value.toString().compareTo(cps.getObjName()) == 0) {
  1500. imgR = Util.loadImage(this, cps.getImage(), 50,
  1501. 50);
  1502. if (imgR != null) {
  1503. label.setIcon(new ImageIcon(imgR));
  1504. }
  1505. label.setText(cps.getName());
  1506. }
  1507. }
  1508. }
  1509. }
  1510. tree.setRowHeight(50);
  1511. if (hasFocus) {
  1512. label.setForeground(new Color(0, 0, 255));
  1513. label.setOpaque(true);
  1514. }
  1515. if (label.getText().length() == 0) {
  1516. label.setText(value.toString());
  1517. if (value.toString().compareTo("Categories") != 0) {
  1518. label.setIcon(new ImageIcon(Util.loadImage(this,
  1519. "/Images/folder.png")));
  1520. }
  1521. }
  1522. return label;
  1523. }
  1524. };
  1525. tree.setCellRenderer(customRenderer);
  1526. tree.addMouseMotionListener(new MouseMotionAdapter() {
  1527. public void mouseDragged(MouseEvent e){
  1528. checkForDragAndDrop(e);
  1529. }
  1530. /**
  1531. * checks if an object of the current Panel
  1532. * could be replaced by the dragged object
  1533. * @param e
  1534. */
  1535. private void checkForDragAndDrop(MouseEvent e){
  1536. try {
  1537. /**
  1538. * if no object gets dragged -> finished
  1539. */
  1540. if(!dragging)return;
  1541. /**
  1542. * select the current Panel
  1543. */
  1544. chooseTabTemp();
  1545. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  1546. if(scrollPane == null)return;
  1547. Component canvasOrUpperNodeCanvas = scrollPane
  1548. .getViewport().getComponent(0);
  1549. /**
  1550. * check for replacements on the canvas
  1551. */
  1552. if (canvasOrUpperNodeCanvas instanceof UpperNodeCanvas) {
  1553. UpperNodeCanvas unc = (UpperNodeCanvas) canvasOrUpperNodeCanvas;
  1554. if(unc.getMousePosition()==null)return;
  1555. int x = (int) unc.getMousePosition().getX()+16;
  1556. int y = (int) unc.getMousePosition().getY()+16;
  1557. /**
  1558. * if in upperNode
  1559. */
  1560. if (x <= unc.upperNode.getLeftBorder()) return;
  1561. /**
  1562. * check for replacement
  1563. */
  1564. unc.checkForReplacement(x, y);
  1565. /**
  1566. * repaint
  1567. */
  1568. unc.invalidate();
  1569. unc.repaint();
  1570. } else {
  1571. if(canvas.getMousePosition()==null)return;
  1572. int x = (int) canvas.getMousePosition().getX()+16;
  1573. int y = (int) canvas.getMousePosition().getY()+16;
  1574. /**
  1575. * check for replacement
  1576. */
  1577. canvas.checkForReplacement(x, y);
  1578. /**
  1579. * repaint
  1580. */
  1581. canvas.invalidate();
  1582. canvas.repaint();
  1583. }
  1584. contentPane.updateUI();
  1585. } catch (Exception eex) {
  1586. eex.printStackTrace();
  1587. }
  1588. }});
  1589. tree.addMouseListener(new MouseAdapter() {
  1590. public void mouseReleased(MouseEvent e) {
  1591. try {
  1592. if (dragging) {
  1593. chooseTabTemp();
  1594. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  1595. Component canvasOrUpperNodeCanvas = scrollPane
  1596. .getViewport().getComponent(0);
  1597. if (canvasOrUpperNodeCanvas instanceof UpperNodeCanvas) {
  1598. UpperNodeCanvas unc = (UpperNodeCanvas) canvasOrUpperNodeCanvas;
  1599. int x = (int) unc.getMousePosition().getX() + 16;
  1600. int y = (int) unc.getMousePosition().getY() + 16;
  1601. if (x > unc.upperNode.getLeftBorder()) {
  1602. AbstractCpsObject h = null;
  1603. if (tempCps instanceof HolonObject) {
  1604. h = new HolonObject(tempCps);
  1605. }
  1606. if (tempCps instanceof HolonSwitch) {
  1607. h = new HolonSwitch(tempCps);
  1608. }
  1609. if (tempCps instanceof HolonTransformer) {
  1610. h = new HolonTransformer(tempCps);
  1611. }
  1612. if (tempCps instanceof HolonBattery)
  1613. {
  1614. h = new HolonBattery(tempCps);
  1615. }
  1616. h.setPosition(x, y);
  1617. controller.addObjUpperNode(h, unc.upperNode);
  1618. /**
  1619. * object would be replaced
  1620. */
  1621. unc.mayBeReplaced = null;
  1622. unc.invalidate();
  1623. unc.repaint();
  1624. unc.setXY((int) canvas.getMousePosition()
  1625. .getX(), (int) canvas
  1626. .getMousePosition().getY());
  1627. }
  1628. } else {
  1629. int x = (int) canvas.getMousePosition().getX() + 16;
  1630. int y = (int) canvas.getMousePosition().getY() + 16;
  1631. AbstractCpsObject h = null;
  1632. if (tempCps instanceof HolonObject) {
  1633. h = new HolonObject(tempCps);
  1634. }
  1635. if (tempCps instanceof HolonSwitch) {
  1636. h = new HolonSwitch(tempCps);
  1637. }
  1638. if (tempCps instanceof HolonTransformer) {
  1639. h = new HolonTransformer(tempCps);
  1640. }
  1641. if (tempCps instanceof HolonBattery)
  1642. {
  1643. h = new HolonBattery(tempCps);
  1644. }
  1645. h.setPosition(x, y);
  1646. controller.addObjectCanvas(h);
  1647. /**
  1648. * no object should get replaced
  1649. */
  1650. canvas.mayBeReplaced = null;
  1651. canvas.invalidate();
  1652. canvas.setXY(
  1653. (int) canvas.getMousePosition().getX(),
  1654. (int) canvas.getMousePosition().getY());
  1655. canvas.repaint();
  1656. }
  1657. controller.calculateStateForCurrentTimeStep();
  1658. contentPane.updateUI();
  1659. dragging = false;
  1660. }
  1661. } catch (Exception eex) {
  1662. }
  1663. frmCyberPhysical.setCursor(new Cursor(Cursor.DEFAULT_CURSOR));
  1664. }
  1665. });
  1666. popmenuEdit.add(editItem);
  1667. editItem.setEnabled(false);
  1668. editItem.addActionListener(actionEvent -> {
  1669. });
  1670. tree.addMouseListener(new MouseAdapter() {
  1671. public void mousePressed(MouseEvent e) {
  1672. try {
  1673. actualObjectClicked = tree
  1674. .getPathForLocation(e.getX(), e.getY())
  1675. .getLastPathComponent().toString();
  1676. // if an Object was selected, the porperties are shown in
  1677. // the table
  1678. DefaultMutableTreeNode selectedNode = (DefaultMutableTreeNode) tree
  1679. .getPathForLocation(e.getX(), e.getY())
  1680. .getLastPathComponent();
  1681. if (selectedNode.getLevel() == 2) {
  1682. controller.searchCategoryObject(selectedNode
  1683. .getParent().toString(), selectedNode
  1684. .toString());
  1685. updCon.deleteRows(model.getSingleTable());
  1686. updCon.deleteRows(model.getMultiTable());
  1687. // if (selected instanceof HolonObject && selected !=
  1688. // null) {
  1689. // selected = (HolonObject) selected;
  1690. // fillElementTable(((HolonObject)
  1691. // selected).getElements());
  1692. // }
  1693. }
  1694. if (SwingUtilities.isRightMouseButton(e)) {
  1695. for (Category cat : model.getCategories()) {
  1696. for (AbstractCpsObject cps : cat.getObjects()) {
  1697. if (actualObjectClicked.compareTo(cps
  1698. .getObjName()) == 0
  1699. && !(cps instanceof HolonSwitch)) {
  1700. editItem.setEnabled(true);
  1701. popmenuEdit.show(e.getComponent(),
  1702. e.getX(), e.getY());
  1703. catOfObjToBeEdited = selectedNode
  1704. .getParent().toString();
  1705. tempCps = cps;
  1706. }
  1707. }
  1708. }
  1709. } else {
  1710. for (Category cat : model.getCategories()) {
  1711. for (AbstractCpsObject cps : cat.getObjects()) {
  1712. if (actualObjectClicked.compareTo(cps
  1713. .getObjName()) == 0) {
  1714. File checkPath = new File(cps.getImage());
  1715. if (checkPath.exists()) {
  1716. img = new ImageIcon(cps.getImage())
  1717. .getImage()
  1718. .getScaledInstance(
  1719. 32,
  1720. 32,
  1721. java.awt.Image.SCALE_SMOOTH);
  1722. } else {
  1723. img = Util.loadImage(this,
  1724. cps.getImage(), 32, 32);
  1725. }
  1726. tempCps = cps;
  1727. dragging = true;
  1728. Cursor cursor = Toolkit.getDefaultToolkit()
  1729. .createCustomCursor(img,
  1730. new Point(0, 0), "Image");
  1731. frmCyberPhysical.setCursor(cursor);
  1732. }
  1733. }
  1734. }
  1735. }
  1736. } catch (Exception eex) {
  1737. }
  1738. }
  1739. });
  1740. editItem.addActionListener(actionEvent -> {
  1741. // Remove the selected Object object
  1742. //AddObjectPopUp(boolean edit, AbstractCpsObject obj, String cat, JFrame parentFrame)
  1743. addObjectPopUP = new AddObjectPopUp(true, tempCps,
  1744. catOfObjToBeEdited, frmCyberPhysical);
  1745. addObjectPopUP.setCategory(catOfObjToBeEdited);
  1746. addObjectPopUP.setController(controller);
  1747. addObjectPopUP.setVisible(true);
  1748. });
  1749. scrollPane1.setViewportView(tree);
  1750. scrollPane1.setColumnHeaderView(panel);
  1751. panel.setLayout(new BoxLayout(panel, BoxLayout.Y_AXIS));
  1752. toolBar.setAlignmentX(Component.LEFT_ALIGNMENT);
  1753. toolBar.setFloatable(false);
  1754. panel.add(toolBar);
  1755. comboBox.setMaximumSize(new Dimension(100, 20));
  1756. //toolBar.add(comboBox);
  1757. //comboBox.setModel(new DefaultComboBoxModel(comboBoxCat));
  1758. // Add Buttonnew DefaultComboBoxModel(comboBoxCat)
  1759. btnAdd.addActionListener(actionEvent -> {
  1760. JOptionPane.showMessageDialog(contentPane, "Work in Progress" , "Message" , JOptionPane.WARNING_MESSAGE);
  1761. /*
  1762. Object nodeInfo = tree.getLastSelectedPathComponent();
  1763. String selectedOption = comboBox.getSelectedItem().toString();
  1764. DefaultMutableTreeNode selectedNode = (DefaultMutableTreeNode) nodeInfo;
  1765. try {
  1766. switch (selectedOption) {
  1767. case "Category":
  1768. String catName = JOptionPane.showInputDialog(
  1769. frmCyberPhysical, Languages.getLanguage()[56]);
  1770. if (catName.length() != 0) {
  1771. controller.addCategory(catName);
  1772. }
  1773. break;
  1774. case "Object":
  1775. if (selectedNode == null) {
  1776. JOptionPane.showMessageDialog(frmCyberPhysical,
  1777. Languages.getLanguage()[57] + selectedOption
  1778. + ".");
  1779. }
  1780. if (selectedNode != null && selectedNode.getLevel() == 1) {
  1781. AbstractCpsObject tmp = new HolonObject("");
  1782. addObjectPopUP = new AddObjectPopUp(false, tmp, null,
  1783. frmCyberPhysical);
  1784. addObjectPopUP.setVisible(true);
  1785. addObjectPopUP.setController(controller);
  1786. addObjectPopUP.setCategory(selectedNode.toString());
  1787. }
  1788. break;
  1789. default:
  1790. addObjectAction(selectedOption, selectedNode);
  1791. break;
  1792. }
  1793. } catch (Exception e) {
  1794. }
  1795. tree.repaint();
  1796. */
  1797. });
  1798. /**
  1799. * Help Menu Action Listeners
  1800. */
  1801. /**
  1802. * URL of the telecommunication git Wiki
  1803. */
  1804. String tkWikiWebpage = "https://git.tk.informatik.tu-darmstadt.de/carlos.garcia/praktikum-holons/wiki/";
  1805. /** open Introduction Web Page */
  1806. mntmIntroduction.addMouseListener(new MouseAdapter() {
  1807. @Override
  1808. public void mousePressed(MouseEvent e){
  1809. openWebpage(tkWikiWebpage + "Introduction+V2.1");
  1810. }
  1811. });
  1812. /** open UserManual WebPage */
  1813. mntmUserManual.addMouseListener(new MouseAdapter() {
  1814. @Override
  1815. public void mousePressed(MouseEvent e){
  1816. openWebpage(tkWikiWebpage + "User+Manual+V2.1");
  1817. }
  1818. });
  1819. /** open Algorithm Help Web Page*/
  1820. mntmAlgorithmHelp.addMouseListener(new MouseAdapter() {
  1821. @Override
  1822. public void mousePressed(MouseEvent e){
  1823. openWebpage(tkWikiWebpage + "Algorithms+V2.1");
  1824. }
  1825. });
  1826. /** open Code Documentation Web Page */
  1827. mntmCodeDoc.addMouseListener(new MouseAdapter() {
  1828. @Override
  1829. public void mousePressed(MouseEvent e){
  1830. openWebpage(tkWikiWebpage + "Code+documentation+V2.1");
  1831. }
  1832. });
  1833. /**
  1834. * Pop up - About Us with some important information about the
  1835. * developers, source and programming stuff
  1836. */
  1837. mntmAboutUs.addMouseListener(new MouseAdapter() {
  1838. @Override
  1839. public void mousePressed(MouseEvent e) {
  1840. aboutUsPopUp = new AboutUsPopUp(frmCyberPhysical);
  1841. aboutUsPopUp.setVisible(true);
  1842. }
  1843. });
  1844. /**
  1845. * Update of every interaction between the user and the canvas (only on
  1846. * the canvas). Basically the update of all the information concerning
  1847. * the clicked HolonObject. For multi-selection, the propertyTable would
  1848. * be disabled
  1849. */
  1850. canvas.addMouseListener(new MouseAdapter() {
  1851. @Override
  1852. public void mousePressed(MouseEvent e) {
  1853. }
  1854. @Override
  1855. public void mouseReleased(MouseEvent e) {
  1856. holonEleNamesDisplayed = Languages.getLanguage()[25];
  1857. // If any empty space is clicked
  1858. if (temp == null || temp.getId() != model.getSelectedObjectID()) {
  1859. hideScrollGraph();
  1860. elementGraph.setText(Languages.getLanguage()[25]);
  1861. }
  1862. temp = updCon.getActualCps();
  1863. // Erase old data in the PropertyTable
  1864. if (model.getPropertyTable().getRowCount() > 0) {
  1865. for (int i = model.getPropertyTable().getRowCount() - 1; i > -1; i--) {
  1866. model.getPropertyTable().removeRow(i);
  1867. }
  1868. }
  1869. if (e.isControlDown() && temp != null) {
  1870. if (model.getSelectedCpsObjects().contains(temp)) {
  1871. controller.deleteSelectedObject(temp);
  1872. } else {
  1873. controller.addSelectedObject(temp);
  1874. }
  1875. }
  1876. if (temp instanceof HolonSwitch) {
  1877. showScrollGraph();
  1878. repaintGraphAux((HolonSwitch)temp);
  1879. unitGraph.fillArrayofBooleans();
  1880. }
  1881. // Write new data in the PropertyTable
  1882. triggerUpdateController(temp);
  1883. // New Tab with NodeOfNode
  1884. if (doubleClick() && MouseEvent.BUTTON3 != e.getButton()
  1885. && temp instanceof CpsUpperNode) {
  1886. openNewUpperNodeTab();
  1887. try {
  1888. controller.autoSave();
  1889. } catch (IOException e1) {
  1890. e1.printStackTrace();
  1891. }
  1892. }
  1893. if (model.getSelectedCpsObjects().size() > 1) {
  1894. model.getTableHolonElement()
  1895. .setModel(model.getMultiTable());
  1896. } else if (model.getSelectedCpsObjects().size() == 1) {
  1897. model.getTableHolonElement().setModel(
  1898. model.getSingleTable());
  1899. }
  1900. }
  1901. });
  1902. holonCanvas.addMouseListener(new MouseAdapter() {
  1903. @Override
  1904. public void mousePressed(MouseEvent e) {
  1905. hideScrollGraph();
  1906. elementGraph.setText(Languages.getLanguage()[25]);
  1907. if (model.getPropertyTable().getRowCount() > 0) {
  1908. for (int i = model.getPropertyTable().getRowCount() - 1; i > -1; i--) {
  1909. model.getPropertyTable().removeRow(i);
  1910. }
  1911. }
  1912. updCon.deleteRows(model.getMultiTable());
  1913. updCon.deleteRows(model.getSingleTable());
  1914. updCon.paintHolonBody(model.getSelectedHolonBody());
  1915. }
  1916. });
  1917. toolBar.add(btnAdd);
  1918. // Del Button
  1919. btnDel.addActionListener(actionEvent -> {
  1920. Object nodeInfo = tree.getLastSelectedPathComponent();
  1921. if (nodeInfo != null) {
  1922. DefaultMutableTreeNode selectedNode = (DefaultMutableTreeNode) nodeInfo;
  1923. String nodeName = selectedNode.getUserObject().toString();
  1924. int depthOfNode = selectedNode.getLevel();
  1925. try {
  1926. switch (depthOfNode) {
  1927. case 1:
  1928. int dialogResult = JOptionPane.showConfirmDialog(
  1929. frmCyberPhysical, eraseCategory + nodeName
  1930. + "?", warningText,
  1931. JOptionPane.YES_NO_OPTION);
  1932. if (dialogResult == JOptionPane.YES_OPTION) {
  1933. controller.deleteCategory(nodeName);
  1934. }
  1935. break;
  1936. case 2:
  1937. DefaultMutableTreeNode parent = (DefaultMutableTreeNode) selectedNode
  1938. .getParent();
  1939. controller.delObjectCategory(parent.getUserObject()
  1940. .toString(), nodeName);
  1941. break;
  1942. default:
  1943. JOptionPane.showMessageDialog(frmCyberPhysical,
  1944. selectObjBeforeErase);
  1945. }
  1946. } catch (Exception e2) {
  1947. }
  1948. } else {
  1949. JOptionPane.showMessageDialog(frmCyberPhysical,
  1950. selectObjBeforeErase);
  1951. }
  1952. tree.repaint();
  1953. });
  1954. toolBar.add(btnDel);
  1955. frmCyberPhysical.getContentPane().add(splitPane);
  1956. mntmNew.addActionListener(actionEvent -> {
  1957. if (model.getObjectsOnCanvas().size() != 0) {
  1958. int newWarning = JOptionPane.YES_NO_OPTION;
  1959. int dialogForNewWarning = JOptionPane.showConfirmDialog(
  1960. frmCyberPhysical, saveBeforeNew, warningText,
  1961. newWarning);
  1962. if (dialogForNewWarning == JOptionPane.YES_OPTION) {
  1963. mntmSave.doClick();
  1964. }
  1965. }
  1966. model.getEdgesOnCanvas().removeAll(model.getEdgesOnCanvas());
  1967. model.getObjectsOnCanvas().removeAll(model.getObjectsOnCanvas());
  1968. controller.setSelectedObjectID(0);
  1969. controller.setSelecteEdge(null);
  1970. controller.setCurIteration(0);
  1971. hideScrollGraph();
  1972. elementGraph.setText(Languages.getLanguage()[25]);
  1973. canvas.tempCps = null;
  1974. canvas.repaint();
  1975. IdCounter.resetCounter();
  1976. IdCounterElem.resetCounter();
  1977. });
  1978. mntmOpen.addActionListener(new ActionListener() {
  1979. @Override
  1980. public void actionPerformed(ActionEvent evt) {
  1981. menuFileExitActionPerformed();
  1982. }
  1983. private void menuFileExitActionPerformed() {
  1984. JFileChooser fileChooser = new JFileChooser();
  1985. FileNameExtensionFilter holonFilter = new FileNameExtensionFilter(
  1986. "Holon Save File(*.holon)", "holon");
  1987. fileChooser.setFileFilter(holonFilter);
  1988. if (fileChooser.showOpenDialog(frmCyberPhysical) == JFileChooser.APPROVE_OPTION) {
  1989. File file = fileChooser.getSelectedFile();
  1990. try {
  1991. controller.loadFile(file.getAbsolutePath());
  1992. canvas.repaint();
  1993. unitGraph.update(model.getObjectsOnCanvas());
  1994. tree.repaint();
  1995. for (JsonObject json : model.getStatisticData()) {
  1996. readStatistics(json);
  1997. }
  1998. } catch (IOException | ArchiveException e) {
  1999. e.printStackTrace();
  2000. JLabel message = new JLabel(
  2001. "The savefile is corrupt and cannot be opened.");
  2002. JOptionPane.showMessageDialog(frmCyberPhysical,
  2003. message, "", JOptionPane.ERROR_MESSAGE);
  2004. }
  2005. }
  2006. }
  2007. });
  2008. mntmSave.addActionListener(new ActionListener() {
  2009. @Override
  2010. public void actionPerformed(ActionEvent evt) {
  2011. menuSaveActionPerformed();
  2012. }
  2013. private void menuSaveActionPerformed() {
  2014. JFileChooser fileChooser = new JFileChooser();
  2015. FileNameExtensionFilter holonFilter = new FileNameExtensionFilter(
  2016. "Holon Save File(*.holon)", "holon");
  2017. fileChooser.setFileFilter(holonFilter);
  2018. if (fileChooser.showSaveDialog(frmCyberPhysical) == JFileChooser.APPROVE_OPTION) {
  2019. String file = fileChooser.getSelectedFile().getPath();
  2020. if (fileChooser.getFileFilter().equals(holonFilter)) {
  2021. if (!file.contains("."))
  2022. file += ".holon";
  2023. }
  2024. if (!file.endsWith(".holon")) {
  2025. String suffix = file.substring(file.lastIndexOf("."),
  2026. file.length());
  2027. String[] options = new String[] { "keep .holon",
  2028. "use " + suffix };
  2029. JLabel message = new JLabel(
  2030. "Are you sure to use the extension \"" + suffix
  2031. + "\" instead of \".holon\"?");
  2032. int response = JOptionPane.showOptionDialog(
  2033. frmCyberPhysical, message, "",
  2034. JOptionPane.DEFAULT_OPTION,
  2035. JOptionPane.QUESTION_MESSAGE, null, options,
  2036. options[1]);
  2037. if (response == 0)
  2038. file = file.replace(suffix, ".holon");
  2039. }
  2040. try {
  2041. controller.saveFile(new File(file).getAbsolutePath());
  2042. } catch (IOException | ArchiveException e) {
  2043. e.printStackTrace();
  2044. }
  2045. }
  2046. }
  2047. });
  2048. englishBtn.addActionListener(actionEvent -> {
  2049. Languages.setLanguage(0);
  2050. refreshLanguages();
  2051. updCon.refreshTableProperties(model.getPropertyTable());
  2052. });
  2053. spanishBtn.addActionListener(actionEvent -> {
  2054. Languages.setLanguage(1);
  2055. refreshLanguages();
  2056. updCon.refreshTableProperties(model.getPropertyTable());
  2057. });
  2058. germanBtn.addActionListener(actionEvent -> {
  2059. Languages.setLanguage(2);
  2060. refreshLanguages();
  2061. updCon.refreshTableProperties(model.getPropertyTable());
  2062. });
  2063. czechBtn.addActionListener(actionEvent -> {
  2064. Languages.setLanguage(3);
  2065. refreshLanguages();
  2066. updCon.refreshTableProperties(model.getPropertyTable());
  2067. });
  2068. chineseBtn.addActionListener(actionEvent -> {
  2069. Languages.setLanguage(4);
  2070. refreshLanguages();
  2071. updCon.refreshTableProperties(model.getPropertyTable());
  2072. });
  2073. mntmUndo.addActionListener(new ActionListener() {
  2074. @Override
  2075. public void actionPerformed(ActionEvent evt) {
  2076. menuUndoActionPerformed();
  2077. }
  2078. private void menuUndoActionPerformed() {
  2079. try {
  2080. controller.loadAutoSave(controller.getUndoSave());
  2081. canvas.repaint();
  2082. repaintGraphAfterUndoRedo();
  2083. hideScrollGraph();
  2084. } catch (IOException e) {
  2085. e.printStackTrace();
  2086. }
  2087. }
  2088. });
  2089. mntmRedo.addActionListener(new ActionListener() {
  2090. @Override
  2091. public void actionPerformed(ActionEvent evt) {
  2092. menuRedoActionPerformed();
  2093. }
  2094. private void menuRedoActionPerformed() {
  2095. try {
  2096. controller.loadAutoSave(controller.getRedoSave());
  2097. canvas.repaint();
  2098. repaintGraphAfterUndoRedo();
  2099. hideScrollGraph();
  2100. } catch (IOException e) {
  2101. e.printStackTrace();
  2102. }
  2103. }
  2104. });
  2105. timePanel = new TimePanel(this,controller);
  2106. timePanel.setBorder(null);
  2107. ((JSlider)
  2108. (
  2109. ((Container)timePanel.getComponent(1))//timePanel
  2110. .getComponent(1)//timeSlider
  2111. )
  2112. )//TODO: This hardcoded stuff
  2113. .addChangeListener(changeEvent -> {
  2114. int i = model.getCurIteration();
  2115. controller.calculateStateForTimeStep(i);
  2116. unitGraph.repaint();
  2117. if (model.getIsSimRunning()) {
  2118. controller.runAlgorithm(model, controller);
  2119. statSplitPane.repaintGraphs();
  2120. }
  2121. contentPane.updateUI();
  2122. });
  2123. splitPane1.setMinimumSize(new Dimension(0, 25));
  2124. splitPane.setRightComponent(splitPane1);
  2125. splitPane.setDividerLocation(200);
  2126. splitPane1.setDividerLocation(500);
  2127. splitPaneCanvasConsole.setDividerLocation(550);
  2128. splitPaneCanvasConsole.setResizeWeight(0.9);
  2129. splitPane.setLeftComponent(scrollPane1);
  2130. splitPaneCanvasConsole.setLeftComponent(tabbedPaneOriginal);
  2131. tabbedPaneOriginal.addTab("View", tabbedPaneInnerOriginal);
  2132. tabbedPaneInnerOriginal.addTab("Main Grid", canvasSP);
  2133. tabbedPaneOriginal.addTab("Statistics", statScrollPane);
  2134. tabbedPaneOriginal.addTab("Holon", holonCanvas);
  2135. FlexiblePane flexPane = new FlexiblePane(controller);
  2136. controller.setFlexiblePane(flexPane);
  2137. controller.getModel().getObjectListeners().add(flexPane);
  2138. tabbedPaneOriginal.addTab("Flexibility", flexPane);
  2139. splitPaneCanvasConsole.setRightComponent(console);
  2140. splitPane1.setLeftComponent(splitPaneCanvasConsole);
  2141. splitPane1.setRightComponent(splitHolonElPro);
  2142. splitPane1.setResizeWeight(0.9);
  2143. splitHolonElPro.setDividerLocation(700);
  2144. // containing the graph and the elements-list
  2145. splitHolonElPro.setTopComponent(splitGraphHolonEl);
  2146. // containing the object's properties
  2147. splitHolonElPro.setBottomComponent(scrollProperties);
  2148. splitGraphHolonEl.setDividerLocation(distanceBetweenElementsAndGraph);
  2149. splitGraphHolonEl.setTopComponent(scrollElements);
  2150. splitGraphHolonEl.setBottomComponent(scrollGraph);
  2151. canvasSP.setViewportView(canvas);
  2152. algorithmMenu.setBackground(new Color(240, 240, 240));
  2153. tabbedPaneOriginal.setBorder(null);
  2154. scrollProperties.setBorder(null);
  2155. scrollGraph.setBorder(null);
  2156. scrollElements.setBorder(null);
  2157. splitPane.setBorder(null);
  2158. splitPane1.setBorder(null);
  2159. splitPaneCanvasConsole.setBorder(null);
  2160. splitHolonElPro.setBorder(null);
  2161. splitGraphHolonEl.setBorder(null);
  2162. panelHolonEl.setBorder(null);
  2163. canvasSP.setBorder(null);
  2164. tableHolonElementScrollPane.setBorder(null);
  2165. frmCyberPhysical.getContentPane().add(timePanel, BorderLayout.SOUTH);
  2166. MouseAdapter focusCanvasAdapter = new FocusCanvasMouseAdapter();
  2167. model.getTableHolonElement().addMouseListener(focusCanvasAdapter);
  2168. tableProperties.addMouseListener(focusCanvasAdapter);
  2169. console.getConsoleText().addMouseListener(focusCanvasAdapter);
  2170. try {
  2171. controller.loadAutoSave(System.getProperty("user.home")
  2172. + "/.config/HolonGUI/Category/Category.json");
  2173. } catch (IOException e1) {
  2174. }
  2175. String autoPath = System.getProperty("user.home")
  2176. + "/.config/HolonGUI/Autosave/";
  2177. File dest = new File(autoPath);
  2178. ArrayList<File> oldAutoSaves = controller.filterOldAutoSaveFiles();
  2179. int nrOfOldSaves = oldAutoSaves.size();
  2180. if (nrOfOldSaves > 0) {
  2181. int dialogButton = JOptionPane.YES_NO_OPTION;
  2182. int dialogResult = JOptionPane.showConfirmDialog(frmCyberPhysical,
  2183. "Old autosave file was found, should it be loaded?",
  2184. warningText, dialogButton);
  2185. if (dialogResult == JOptionPane.YES_OPTION) {
  2186. if (dest.exists()) {
  2187. model.setAutoSaveNr(nrOfOldSaves - 1);
  2188. mntmRedo.doClick();
  2189. } else {
  2190. JOptionPane.showMessageDialog(frmCyberPhysical,
  2191. "Autosave could not be loaded.");
  2192. setUpAutoSave(dest);
  2193. }
  2194. } else {
  2195. setUpAutoSave(dest);
  2196. }
  2197. // after all: delete the obsolete/old autosave files from the
  2198. // directory
  2199. controller.deleteObsoleteAutoSaveFiles();
  2200. }
  2201. canvasSP.addComponentListener(new ComponentAdapter() {
  2202. @Override
  2203. public void componentResized(ComponentEvent e) {
  2204. controller.setCanvasX(Math.max(model.getCanvasX(), canvasSP
  2205. .getViewport().getWidth()));
  2206. controller.setCanvasY(Math.max(model.getCanvasY(), canvasSP
  2207. .getViewport().getHeight()));
  2208. canvas.repaint();
  2209. }
  2210. });
  2211. }
  2212. private void showScrollGraph() {
  2213. scrollGraph.setVisible(true);
  2214. splitGraphHolonEl.setBottomComponent(scrollGraph);
  2215. splitGraphHolonEl.setDividerLocation(distanceBetweenElementsAndGraph);
  2216. }
  2217. private void hideScrollGraph() {
  2218. scrollGraph.setVisible(false);
  2219. unitGraph.empty();
  2220. splitGraphHolonEl.remove(scrollGraph);
  2221. splitGraphHolonEl.setDividerLocation(0);
  2222. }
  2223. private boolean isUpperPanelInsideBounds() {
  2224. int x = frmCyberPhysical.getX();
  2225. int y = frmCyberPhysical.getY();
  2226. int width = frmCyberPhysical.getWidth();
  2227. // get all connected screen devices
  2228. GraphicsDevice[] screenDevices = GraphicsEnvironment
  2229. .getLocalGraphicsEnvironment().getScreenDevices();
  2230. boolean isUpperPanelVisible = false;
  2231. // and check whether they contain the upper left or upper right point of
  2232. // the frame
  2233. for (GraphicsDevice device : screenDevices) {
  2234. Rectangle bounds = device.getDefaultConfiguration().getBounds();
  2235. if (bounds.contains(x, y) || bounds.contains(x + width, y)) {
  2236. isUpperPanelVisible = true;
  2237. break;
  2238. }
  2239. }
  2240. return isUpperPanelVisible;
  2241. }
  2242. /**
  2243. * Sets up autosave if no old one is loaded at the beginning
  2244. *
  2245. * @param dest
  2246. * path to save-folder
  2247. */
  2248. private void setUpAutoSave(File dest) {
  2249. dest.mkdirs();
  2250. try {
  2251. controller.autoSave();
  2252. } catch (IOException e1) {
  2253. e1.printStackTrace();
  2254. }
  2255. }
  2256. /**
  2257. * adds a specific object type to selected Category also handles input
  2258. * windows and illegal inputs.
  2259. *
  2260. * @param objType
  2261. * type of the Object
  2262. * @param selectedNode
  2263. * The selected Node
  2264. */
  2265. private void addObjectAction(String objType,
  2266. DefaultMutableTreeNode selectedNode) {
  2267. if (selectedNode == null) {
  2268. JOptionPane.showMessageDialog(frmCyberPhysical,
  2269. "Please select a Category first before adding " + objType
  2270. + ".");
  2271. }
  2272. // if selected node is a directory for Categories
  2273. else {
  2274. if (selectedNode.getLevel() == 1) {
  2275. String objname = JOptionPane.showInputDialog(frmCyberPhysical,
  2276. "Please enter a Name for the " + objType);
  2277. Category cat = controller.searchCategory(selectedNode
  2278. .getUserObject().toString());
  2279. if (objname.length() != 0) {
  2280. try {
  2281. switch (objType) {
  2282. case "Switch":
  2283. controller.addSwitch(cat, objname);
  2284. break;
  2285. case "Battery":
  2286. controller.addBattery(cat, objname);
  2287. break;
  2288. }
  2289. } catch (Exception e) {
  2290. }
  2291. }
  2292. } else {
  2293. JOptionPane
  2294. .showMessageDialog(frmCyberPhysical,
  2295. "Objects can not be added to Objects. Please select a Category.");
  2296. }
  2297. }
  2298. }
  2299. /**
  2300. * reloads the Categories from Model.
  2301. *
  2302. * @param categories
  2303. * the current categories
  2304. */
  2305. private void updateCategories(final ArrayList<Category> categories) {
  2306. tree.setModel(new DefaultTreeModel(new DefaultMutableTreeNode(
  2307. "Categories") {
  2308. private static final long serialVersionUID = 1L;
  2309. {
  2310. DefaultMutableTreeNode node1;
  2311. for (Category c : categories) {
  2312. node1 = new DefaultMutableTreeNode(c.getName());
  2313. // kann eventuell umgeändert werden
  2314. for (AbstractCpsObject obj : c.getObjects()) {
  2315. node1.add(new DefaultMutableTreeNode(obj.getObjName()));
  2316. }
  2317. add(node1);
  2318. }
  2319. }
  2320. }));
  2321. }
  2322. /**
  2323. * When changes are made to the Categories.
  2324. *
  2325. * @param categories
  2326. * the Categories
  2327. */
  2328. public void onChange(ArrayList<Category> categories) {
  2329. DefaultTreeModel model = (DefaultTreeModel) tree.getModel();
  2330. updateCategories(categories);
  2331. model.reload();
  2332. }
  2333. /**
  2334. * Get the Frame.
  2335. *
  2336. * @return the Frame
  2337. */
  2338. JFrame getFrmCyberPhysical() {
  2339. return frmCyberPhysical;
  2340. }
  2341. private void refreshLanguages() {
  2342. String[] tempArray = Languages.getLanguage();
  2343. // ToolBar
  2344. mnNewMenu.setText(tempArray[0]);
  2345. mntmNew.setText(tempArray[1]);
  2346. mntmOpen.setText(tempArray[2]);
  2347. mntmSave.setText(tempArray[3]);
  2348. mnNewMenuEdit.setText(tempArray[4]);
  2349. mntmUndo.setText(tempArray[5]);
  2350. mntmRedo.setText(tempArray[6]);
  2351. mntmFindReplace.setText(tempArray[7]);
  2352. mntmEditShowedInformation.setText(tempArray[8]);
  2353. mnNewMenuOptions.setText(tempArray[9]);
  2354. mntmResetCategory.setText(tempArray[10]);
  2355. mnNewMenuView.setText(tempArray[11]);
  2356. mntmCanvasSize.setText(tempArray[12]);
  2357. mnHelp.setText(tempArray[13]);
  2358. mntmAboutUs.setText(tempArray[14]);
  2359. mntmEditEdges.setText(tempArray[15]);
  2360. mnLanguage.setText(tempArray[16]);
  2361. canvas.updateLanguages();
  2362. // Tables
  2363. System.arraycopy(tempArray, 17, columnNamesMulti, 0,
  2364. columnNamesMulti.length);
  2365. model.getMultiTable().setColumnIdentifiers(columnNamesMulti);
  2366. System.arraycopy(tempArray, 18, columnNamesSingle, 0,
  2367. columnNamesSingle.length);
  2368. model.getSingleTable().setColumnIdentifiers(columnNamesSingle);
  2369. model.colNames[0] = tempArray[23];
  2370. model.colNames[1] = tempArray[24];
  2371. model.getPropertyTable().setColumnIdentifiers(model.colNames);
  2372. // Graph
  2373. elementGraph.setText(tempArray[25]);
  2374. holonEleNamesDisplayed = tempArray[25];
  2375. resetGraphBtn.setText(tempArray[26]);
  2376. // Warning PopUps
  2377. warningText = tempArray[27];
  2378. saveBeforeNew = tempArray[28];
  2379. eraseCategory = tempArray[29];
  2380. selectObjBeforeErase = tempArray[30];
  2381. // SimMenu
  2382. algorithmMenu.algoFolderButton.setText(Languages.getLanguage()[85]);
  2383. // TimePanel
  2384. timePanel.playBtn.setToolTipText(Languages.getLanguage()[89]);
  2385. timePanel.timeResetBtn.setToolTipText(Languages.getLanguage()[90]);
  2386. timePanel.timeForwardBtn.setToolTipText(Languages.getLanguage()[91]);
  2387. timePanel.timeBackwardBtn.setToolTipText(Languages.getLanguage()[92]);
  2388. timePanel.timeSlider.setToolTipText(Languages.getLanguage()[93]);
  2389. // Image Size Slider
  2390. lblImageSize.setText(Languages.getLanguage()[94]);
  2391. }
  2392. /**
  2393. * Checks if a double click was made.
  2394. *
  2395. * @return true if doublecklick, false if not
  2396. */
  2397. private boolean doubleClick() {
  2398. if (click) {
  2399. click = false;
  2400. return true;
  2401. } else {
  2402. click = true;
  2403. Timer t = new Timer("doubleclickTimer", false);
  2404. t.schedule(new TimerTask() {
  2405. @Override
  2406. public void run() {
  2407. click = false;
  2408. }
  2409. }, 350);
  2410. }
  2411. return false;
  2412. }
  2413. /*
  2414. * Open a new Tab with an UpperNodeCanvas
  2415. */
  2416. private void openNewUpperNodeTab() {
  2417. chooseTabTemp();
  2418. JScrollPane scrollPane = getScrollPaneFromTabbedPane();
  2419. if (scrollPane.getViewport().getComponent(0) instanceof MyCanvas) {
  2420. unc = new UpperNodeCanvas(model, controller, unitGraph,
  2421. (CpsUpperNode) temp, "");
  2422. } else {
  2423. unc = new UpperNodeCanvas(model, controller, unitGraph,
  2424. (CpsUpperNode) temp, ((UpperNodeCanvas) scrollPane
  2425. .getViewport().getComponent(0)).path + " -> ");
  2426. }
  2427. unc.setShowedInformation(canvas.getShowedInformation());
  2428. // check if tab already open for clicked NodeOfNode
  2429. boolean dupl = false;
  2430. for (int i = 1; i < tabbedPaneInnerOriginal.getTabCount(); i++) {
  2431. JScrollPane paneOriginal = (JScrollPane) tabbedPaneInnerOriginal
  2432. .getComponentAt(i);
  2433. if (paneOriginal != null
  2434. && ((UpperNodeCanvas) paneOriginal.getViewport()
  2435. .getComponent(0)).upperNode.getId() == temp.getId()) {
  2436. dupl = true;
  2437. // set selected component to view
  2438. tabbedPaneOriginal
  2439. .setSelectedComponent(tabbedPaneInnerOriginal);
  2440. // set selected tab in view to found upper-node-canvas
  2441. tabbedPaneInnerOriginal
  2442. .setSelectedComponent(tabbedPaneInnerOriginal
  2443. .getComponentAt(i));
  2444. }
  2445. if (tabbedPaneSplit.getTabCount() > 0) {
  2446. JTabbedPane tabbedPaneInnerSplit = (JTabbedPane) tabbedPaneSplit
  2447. .getComponentAt(0);
  2448. if (tabbedPaneInnerSplit != null) {
  2449. JScrollPane paneSplit = (JScrollPane) tabbedPaneInnerSplit
  2450. .getComponentAt(i);
  2451. if (!initSplit
  2452. && paneSplit != null
  2453. && ((UpperNodeCanvas) paneSplit.getViewport()
  2454. .getComponent(0)).upperNode.getId() == temp
  2455. .getId()) {
  2456. dupl = true;
  2457. // set selected component to view
  2458. tabbedPaneSplit
  2459. .setSelectedComponent(tabbedPaneInnerSplit);
  2460. // set selected tab in view to found upper-node-canvas
  2461. tabbedPaneInnerSplit
  2462. .setSelectedComponent(tabbedPaneInnerSplit
  2463. .getComponentAt(i));
  2464. }
  2465. }
  2466. }
  2467. // if we found a duplicate, break
  2468. if (dupl) {
  2469. break;
  2470. }
  2471. }
  2472. if (!dupl) {
  2473. unc.setBorder(null);
  2474. unc.setBackground(Color.WHITE);
  2475. unc.setPreferredSize(new Dimension(model.getCanvasX(), model
  2476. .getCanvasY()));
  2477. unc.addMouseListener(new MouseAdapter() {
  2478. @Override
  2479. public void mousePressed(MouseEvent e) {
  2480. hideScrollGraph();
  2481. holonEleNamesDisplayed = Languages.getLanguage()[25];
  2482. elementGraph.setText(holonEleNamesDisplayed);
  2483. chooseTabTemp();
  2484. JScrollPane scrollPane1 = getScrollPaneFromTabbedPane();
  2485. temp = ((UpperNodeCanvas) scrollPane1.getViewport()
  2486. .getComponent(0)).tempCps;
  2487. if (doubleClick() && MouseEvent.BUTTON3 != e.getButton()
  2488. && temp instanceof CpsUpperNode) {
  2489. openNewUpperNodeTab();
  2490. }
  2491. if (temp instanceof HolonSwitch) {
  2492. repaintGraphAux((HolonSwitch)temp);
  2493. unitGraph.fillArrayofBooleans();
  2494. }
  2495. }
  2496. });
  2497. JScrollPane sp = new JScrollPane(unc);
  2498. sp.setBorder(null);
  2499. // Selected tabbed Pane = tabbedPaneOriginal or tabbedPaneSplit
  2500. if (tabTemp == tabbedPaneOriginal) {
  2501. this.tabbedPaneInnerOriginal.add(temp.getName(), sp);
  2502. this.tabbedPaneInnerOriginal.setSelectedComponent(sp);
  2503. this.tabbedPaneInnerOriginal.setTabComponentAt(
  2504. this.tabbedPaneInnerOriginal.getTabCount() - 1,
  2505. new ButtonTabComponent(this.tabbedPaneInnerOriginal,
  2506. tabbedPaneSplit));
  2507. } else {
  2508. JTabbedPane tabbedPaneInnerSplit = (JTabbedPane) tabbedPaneSplit
  2509. .getComponentAt(0);
  2510. tabbedPaneInnerSplit.add(temp.getName(), sp);
  2511. Component tempC = tabbedPaneInnerSplit.getSelectedComponent();
  2512. tabbedPaneInnerSplit.setComponentAt(
  2513. tabbedPaneInnerSplit.getSelectedIndex(), null);
  2514. tabbedPaneOriginal.setComponentAt(
  2515. tabbedPaneInnerSplit.getSelectedIndex(), tempC);
  2516. tabbedPaneInnerSplit.setSelectedComponent(sp);
  2517. tabbedPaneInnerOriginal.add(temp.getName(), null);
  2518. tabbedPaneInnerOriginal.setTabComponentAt(
  2519. tabbedPaneInnerOriginal.getTabCount() - 1,
  2520. new ButtonTabComponent(tabbedPaneInnerOriginal,
  2521. tabbedPaneInnerSplit));
  2522. }
  2523. temp = null;
  2524. }
  2525. }
  2526. private void updateUpperNodes() {
  2527. for (Component c : tabbedPaneInnerOriginal.getComponents()) {
  2528. if (!(c instanceof JScrollPane)) {
  2529. continue;
  2530. }
  2531. Component pane = ((JScrollPane) c).getViewport().getComponent(0);
  2532. if (pane instanceof UpperNodeCanvas) {
  2533. temp = model.getHashcodeMap()
  2534. .get(((UpperNodeCanvas) pane).code);
  2535. ((UpperNodeCanvas) pane).upperNode = (CpsUpperNode) temp;
  2536. }
  2537. }
  2538. }
  2539. /**
  2540. * Removes UpperNodeTab if UpperNode was deleted
  2541. *
  2542. * @param cps
  2543. * the CPS object that is currently selected
  2544. */
  2545. private void removeUpperNodeTab(AbstractCpsObject cps) {
  2546. if (cps instanceof CpsUpperNode) {
  2547. boolean splitView = false;
  2548. for (int i = 1; i < tabbedPaneInnerOriginal.getTabCount(); i++) {
  2549. JScrollPane scrollPaneOriginal = (JScrollPane) tabbedPaneInnerOriginal
  2550. .getComponentAt(i);
  2551. if (scrollPaneOriginal == null) {
  2552. splitView = true;
  2553. } else if (((UpperNodeCanvas) scrollPaneOriginal.getViewport()
  2554. .getComponent(0)).upperNode.getId() == cps.getId()) {
  2555. ((ButtonTabComponent) tabbedPaneInnerOriginal
  2556. .getTabComponentAt(i)).removeTabs();
  2557. break;
  2558. }
  2559. }
  2560. // If SplitView is on and the view on
  2561. // tabbedPaneSplit is the deleted upperNode
  2562. if (splitView && tabbedPaneSplit.getComponentCount() > 0) {
  2563. JTabbedPane tabbedPaneInnerSplit = (JTabbedPane) tabbedPaneSplit
  2564. .getComponentAt(0);
  2565. if (((UpperNodeCanvas) ((JScrollPane) tabbedPaneInnerSplit
  2566. .getSelectedComponent()).getViewport().getComponent(0)).upperNode
  2567. .getId() == cps.getId()) {
  2568. ((ButtonTabComponent) tabbedPaneInnerOriginal
  2569. .getTabComponentAt(tabbedPaneInnerSplit
  2570. .getSelectedIndex())).removeTabs();
  2571. }
  2572. }
  2573. }
  2574. }
  2575. private void readStatistics(JsonObject json) {
  2576. List<String> keys = json.entrySet().stream().map(i -> i.getKey())
  2577. .collect(Collectors.toCollection(ArrayList::new));
  2578. // Saved Values
  2579. JsonObject obj;
  2580. AbstractCpsObject cps;
  2581. int prop;
  2582. Color color;
  2583. StatisticGraphPanel stat = new StatisticGraphPanel(model, controller,//TODO
  2584. json.get("KEY").getAsString(), model.getGraphTable());
  2585. for (String k : keys) {
  2586. if (!k.equals("KEY")) {
  2587. obj = json.get(k).getAsJsonObject();
  2588. cps = (obj.get("ID") == JsonNull.INSTANCE ? null : controller
  2589. .searchTracked(obj.get("ID").getAsInt()));
  2590. prop = obj.get("PROPERTY").getAsInt();
  2591. color = model.getGson().fromJson(obj.get("COLOR"), Color.class);
  2592. stat.addObject(new TrackedDataSet(cps, prop, color, model.getIterations()));
  2593. }
  2594. model.getGraphTable().put(json.get("KEY").getAsString(), stat);
  2595. model.getStatPanel().getGraphPanel().add(stat);
  2596. }
  2597. }
  2598. /**
  2599. * chooses whether to set the tabTemp to tabbedPaneOriginal or
  2600. * tabbedPaneSplit
  2601. */
  2602. private void chooseTabTemp() {
  2603. // is the uppernode on tabbedPaneOriginal or tabbedPaneSplit
  2604. if (tabbedPaneOriginal.getMousePosition() != null) {
  2605. tabTemp = tabbedPaneOriginal;
  2606. } else {
  2607. tabTemp = tabbedPaneSplit;
  2608. }
  2609. }
  2610. private JScrollPane getScrollPaneFromTabbedPane(JTabbedPane tabbedPane,
  2611. int index) {
  2612. tabTemp = tabbedPane;
  2613. return getScrollPaneFromTabbedPane(index);
  2614. }
  2615. // private JScrollPane getScrollPaneFromTabbedPane(JTabbedPane tabbedPane) {
  2616. // return getScrollPaneFromTabbedPane(tabbedPane, -1);
  2617. // }
  2618. private JScrollPane getScrollPaneFromTabbedPane() {
  2619. return getScrollPaneFromTabbedPane(-1);
  2620. }
  2621. private JScrollPane getScrollPaneFromTabbedPane(int index) {
  2622. Component upperLevelSelectedComponent;
  2623. if (index == -1) {
  2624. upperLevelSelectedComponent = tabTemp.getSelectedComponent();
  2625. } else {
  2626. upperLevelSelectedComponent = tabTemp.getComponentAt(index);
  2627. }
  2628. if (upperLevelSelectedComponent instanceof JTabbedPane) {
  2629. return (JScrollPane) ((JTabbedPane) upperLevelSelectedComponent)
  2630. .getSelectedComponent();
  2631. } else if (upperLevelSelectedComponent instanceof JScrollPane) {
  2632. return (JScrollPane) upperLevelSelectedComponent;
  2633. } else {
  2634. return null;
  2635. }
  2636. }
  2637. private void repaintGraphAfterUndoRedo() {
  2638. for (AbstractCpsObject cps : model.getObjectsOnCanvas()) {
  2639. unitGraph.repaintGraph(cps);
  2640. }
  2641. }
  2642. /**
  2643. * if flexibility was turned on, then active needs to be turned off, the
  2644. * energy currently produced/consumed
  2645. *
  2646. * @param eleBTemp
  2647. * element that needs to be updated
  2648. * @param selectedValueBY
  2649. * the y value in the table
  2650. */
  2651. private void updateElementTableAfterChange(HolonElement eleBTemp,
  2652. int selectedValueBY) {
  2653. model.getSingleTable().setValueAt(eleBTemp.isFlexible(),
  2654. selectedValueBY, 6);
  2655. model.getSingleTable().setValueAt(eleBTemp.isActive(), selectedValueBY,
  2656. 5);
  2657. model.getSingleTable().setValueAt(eleBTemp.getAmount(),
  2658. selectedValueBY, 4);
  2659. model.getSingleTable().setValueAt(
  2660. eleBTemp.getFlexibleEnergyAvailablePerElement(),
  2661. selectedValueBY, 3);
  2662. model.getSingleTable().setValueAt(eleBTemp.getEnergyPerElement(),
  2663. selectedValueBY, 2);
  2664. }
  2665. private void triggerUpdateController(AbstractCpsObject temp) {
  2666. if (temp != null) {
  2667. updCon.paintProperties(temp);
  2668. }
  2669. updCon.refreshTableHolonElement(model.getMultiTable(),
  2670. model.getSingleTable());
  2671. updCon.refreshTableProperties(model.getPropertyTable());
  2672. }
  2673. /**
  2674. * Custom Mouse adapter makes contentPane gain focus once mouse leaves this
  2675. * component so copy/paste/cut and "select all" works
  2676. */
  2677. private class FocusCanvasMouseAdapter extends MouseAdapter {
  2678. @Override
  2679. public void mouseExited(MouseEvent e) {
  2680. contentPane.requestFocus();
  2681. }
  2682. }
  2683. private void repaintGraphAux(ArrayList<HolonElement> o){//TODO:
  2684. unitGraph.repaintWithNewElement((ArrayList<HolonElement>)o);
  2685. unitGraphLocalPeriod.setText(""+unitGraph.getLocalPeriod());
  2686. unitGraphStretchMode.setSelected(unitGraph.isStretching());
  2687. }
  2688. private void repaintGraphAux(HolonSwitch o){//TODO:
  2689. unitGraph.repaintWithNewSwitch(o);
  2690. unitGraphLocalPeriod.setText(""+unitGraph.getLocalPeriod());
  2691. unitGraphStretchMode.setSelected(unitGraph.isStretching());
  2692. }
  2693. public void updateIterations() {
  2694. this.statSplitPane.updateIterations();
  2695. }
  2696. private void openWebpage(String URL){
  2697. try {
  2698. java.awt.Desktop.getDesktop().browse(new URI(URL));
  2699. } catch (IOException e1) {
  2700. // TODO Auto-generated catch block
  2701. e1.printStackTrace();
  2702. } catch (URISyntaxException e1) {
  2703. // TODO Auto-generated catch block
  2704. e1.printStackTrace();
  2705. }
  2706. }
  2707. }