GUI.java 104 KB

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