GUI.java 105 KB

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