UpperNodeCanvas.java 38 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228
  1. package ui.view;
  2. import java.awt.BasicStroke;
  3. import java.awt.Color;
  4. import java.awt.Graphics;
  5. import java.awt.Graphics2D;
  6. import java.awt.Image;
  7. import java.awt.Point;
  8. import java.awt.RenderingHints;
  9. import java.awt.event.ActionEvent;
  10. import java.awt.event.ActionListener;
  11. import java.awt.event.MouseEvent;
  12. import java.awt.event.MouseListener;
  13. import java.awt.event.MouseMotionListener;
  14. import java.awt.geom.Line2D;
  15. import java.io.File;
  16. import java.io.IOException;
  17. import java.util.ArrayList;
  18. import java.util.Timer;
  19. import java.util.TimerTask;
  20. import javax.swing.ImageIcon;
  21. import javax.swing.JLabel;
  22. import javax.swing.JMenuItem;
  23. import javax.swing.JPanel;
  24. import javax.swing.JPopupMenu;
  25. import javax.swing.JScrollPane;
  26. import javax.swing.JTabbedPane;
  27. import javax.swing.JToolTip;
  28. import classes.CpsEdge;
  29. import classes.CpsNode;
  30. import classes.CpsUpperNode;
  31. import classes.AbstractCpsObject;
  32. import classes.HolonElement;
  33. import classes.HolonObject;
  34. import classes.HolonSwitch;
  35. import classes.Position;
  36. import classes.SubNet;
  37. import ui.controller.Control;
  38. import ui.controller.UpdateController;
  39. import ui.model.Model;
  40. /**
  41. * This Class is the Canvas. All Objects will be visualized here
  42. *
  43. * @author Gruppe14
  44. */
  45. public class UpperNodeCanvas extends JPanel implements MouseListener, MouseMotionListener {
  46. private static final long serialVersionUID = 1L;
  47. private Image img = null; // Contains the image to draw on MyCanvas
  48. private int x = 0;
  49. private int y = 0;
  50. // edge Object Start Point
  51. private Model model;
  52. private final Control controller;
  53. Graphics2D g2; // For Painting
  54. private int cx, cy;
  55. private int sx, sy; // Mark Coords
  56. private float scalediv20;
  57. public int borderPos = 0; // Border Position
  58. // Path
  59. public String path;
  60. private JLabel breadCrumb;
  61. ArrayList<HolonElement> dataSelected = new ArrayList<HolonElement>();
  62. ArrayList<AbstractCpsObject> tempSelected = new ArrayList<AbstractCpsObject>();
  63. // The UpperNode
  64. public CpsUpperNode upperNode;
  65. private boolean[] showedInformation = new boolean[3];
  66. private boolean dragging = false; // for dragging
  67. private boolean dragged = false; // if an object/objects was/were dragged
  68. private boolean drawEdge = false; // for drawing edges
  69. private boolean click = false; // for double click
  70. private boolean doMark = false; // for double click
  71. public AbstractCpsObject tempCps = null;
  72. private CpsEdge edgeHighlight = null;
  73. // PopUpMenu
  74. private JPopupMenu popmenu = new JPopupMenu();
  75. private JMenuItem itemDelete = new JMenuItem("Delete");
  76. private JMenuItem itemCut = new JMenuItem("Cut");
  77. private JMenuItem itemCopy = new JMenuItem("Copy");
  78. public JMenuItem itemPaste = new JMenuItem("Paste");
  79. public JMenuItem itemGroup = new JMenuItem("Group");
  80. public JMenuItem itemUngroup = new JMenuItem("Ungroup");
  81. public JMenuItem itemTrack = new JMenuItem("Track");
  82. public JMenuItem itemUntrack = new JMenuItem("Untrack");
  83. private JToolTip objectTT = new JToolTip();
  84. private Point mousePosition = new Point(); // Mouse Position when
  85. // rightclicked
  86. // contains the value of the Capacity for new created Edges
  87. private UpdateController updCon;
  88. /**
  89. * Constructor.
  90. *
  91. * @param mod
  92. * the Model
  93. * @param control
  94. * the Controller
  95. */
  96. public UpperNodeCanvas(Model mod, Control control, CpsUpperNode UpperNode, String parentPath) {
  97. this.add(objectTT);
  98. this.controller = control;
  99. this.model = mod;
  100. this.upperNode = UpperNode;
  101. this.path = parentPath + upperNode.getName();
  102. this.breadCrumb = new JLabel(path);
  103. // this.add(breadCrumb);
  104. scalediv20 = model.getScale() / 20;
  105. // Cps objecte aus dem border links schieben
  106. borderPos = (int) (model.getScale() + scalediv20 + scalediv20 + 10);
  107. for (AbstractCpsObject cps : upperNode.getNodes()) {
  108. if (cps.getPosition().x < model.getScaleDiv2() + borderPos + 5) {
  109. cps.setPosition(new Position(borderPos + 5, cps.getPosition().y));
  110. }
  111. }
  112. showedInformation[0] = true;
  113. showedInformation[1] = true;
  114. popmenu.add(itemCut);
  115. popmenu.add(itemCopy);
  116. popmenu.add(itemPaste);
  117. popmenu.add(itemDelete);
  118. popmenu.addSeparator();
  119. popmenu.add(itemGroup);
  120. popmenu.add(itemUngroup);
  121. popmenu.add(itemTrack);
  122. popmenu.add(itemUntrack);
  123. itemDelete.setEnabled(false);
  124. itemCut.setEnabled(false);
  125. itemCopy.setEnabled(false);
  126. itemPaste.setEnabled(false);
  127. itemGroup.setEnabled(false);
  128. itemUngroup.setEnabled(false);
  129. itemTrack.setEnabled(false);
  130. itemUntrack.setEnabled(false);
  131. updCon = new UpdateController(model, controller);
  132. itemGroup.addActionListener(new ActionListener() {
  133. @Override
  134. public void actionPerformed(ActionEvent e) {
  135. controller.addUpperNode("NodeOfNode", upperNode);
  136. repaint();
  137. }
  138. });
  139. itemUngroup.addActionListener(new ActionListener() {
  140. @Override
  141. public void actionPerformed(ActionEvent e) {
  142. controller.delUpperNode((CpsUpperNode) tempCps, upperNode);
  143. repaint();
  144. }
  145. });
  146. itemUntrack.addActionListener(new ActionListener() {
  147. @Override
  148. public void actionPerformed(ActionEvent e) {
  149. for (AbstractCpsObject o : model.getSelectedCpsObjects()) {
  150. if (o instanceof HolonObject) {
  151. boolean found = false;
  152. if (controller.getTrackingObj() != null) {
  153. for (HolonObject obj : controller.getTrackingObj()) {
  154. if (obj.getID() == o.getID()) {
  155. found = true;
  156. }
  157. }
  158. }
  159. if (found) {
  160. // Removed from tracking array and tracking
  161. // information reseted
  162. controller.removeTrackingObj((HolonObject) o);
  163. ((HolonObject) o).setTrackingProd(new float[100]);
  164. ((HolonObject) o).setTrackingCons(new float[100]);
  165. }
  166. controller.addTextToConsole("Untracking: ", Color.BLACK, 12, false, false, false);
  167. controller.addTextToConsole("" + o.getName(), Color.BLUE, 12, true, false, false);
  168. controller.addTextToConsole(", ID:", Color.BLACK, 12, false, false, false);
  169. controller.addTextToConsole("" + o.getID(), Color.RED, 12, true, false, true);
  170. }
  171. }
  172. }
  173. });
  174. itemUntrack.addActionListener(new ActionListener() {
  175. @Override
  176. public void actionPerformed(ActionEvent e) {
  177. for (AbstractCpsObject o : model.getSelectedCpsObjects()) {
  178. if (o instanceof HolonObject) {
  179. boolean found = false;
  180. if (controller.getTrackingObj() != null) {
  181. for (HolonObject obj : controller.getTrackingObj()) {
  182. if (obj.getID() == o.getID()) {
  183. found = true;
  184. }
  185. }
  186. }
  187. if (found) {
  188. // Removed from tracking array and tracking
  189. // information reseted
  190. controller.removeTrackingObj((HolonObject) o);
  191. ((HolonObject) o).setTrackingProd(new float[100]);
  192. ((HolonObject) o).setTrackingCons(new float[100]);
  193. }
  194. }
  195. }
  196. System.out.println(controller.getTrackingObj());
  197. }
  198. });
  199. itemDelete.addActionListener(new ActionListener() {
  200. @Override
  201. public void actionPerformed(ActionEvent e) {
  202. // Remove the selected Object objects
  203. for (AbstractCpsObject cps : model.getSelectedCpsObjects()) {
  204. controller.delObjUpperNode(cps, upperNode);
  205. // Remove UpperNodeTab if UpperNode deleted
  206. if (cps instanceof CpsUpperNode) {
  207. JTabbedPane tabbedPane = (JTabbedPane) getParent().getParent().getParent();
  208. for (int i = 2; i < tabbedPane.getTabCount(); i++) {
  209. if (((UpperNodeCanvas) ((JScrollPane) tabbedPane.getComponentAt(i)).getViewport()
  210. .getComponent(0)).upperNode.getID() == cps.getID()) {
  211. tabbedPane.remove(i);
  212. i = tabbedPane.getTabCount();
  213. }
  214. }
  215. }
  216. }
  217. model.getSelectedCpsObjects().clear();
  218. tempCps = null;
  219. repaint();
  220. }
  221. });
  222. itemCut.addActionListener(new ActionListener() {
  223. @Override
  224. public void actionPerformed(ActionEvent e) {
  225. controller.cutObjects();
  226. itemPaste.setEnabled(true);
  227. repaint();
  228. }
  229. });
  230. itemCopy.addActionListener(new ActionListener() {
  231. @Override
  232. public void actionPerformed(ActionEvent e) {
  233. controller.copyObjects();
  234. itemPaste.setEnabled(true);
  235. repaint();
  236. }
  237. });
  238. itemPaste.addActionListener(new ActionListener() {
  239. @Override
  240. public void actionPerformed(ActionEvent e) {
  241. controller.pasteObjects(mousePosition);
  242. repaint();
  243. }
  244. });
  245. this.addMouseListener(this);
  246. this.addMouseMotionListener(this);
  247. }
  248. /**
  249. * Paints all Components on the Canvas.
  250. *
  251. * @param g
  252. * Graphics
  253. */
  254. public void paintComponent(Graphics g) {
  255. String maxCap;
  256. super.paintComponent(g);
  257. ((JScrollPane) this.getParent().getParent()).setColumnHeaderView(breadCrumb);
  258. // Rendering
  259. g2 = (Graphics2D) g;
  260. RenderingHints rh = new RenderingHints(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
  261. g2.setRenderingHints(rh);
  262. // Left Border
  263. borderPos = (int) (model.getScale() + scalediv20 + scalediv20 + 10);
  264. g2.setColor(new Color(230, 230, 230));
  265. g2.fillRect(0, 0, borderPos, this.getHeight());
  266. g2.setColor(Color.BLACK);
  267. g2.drawLine(0, 0, this.getWidth(), 0);
  268. // Test SubNet Coloring
  269. int i = 0;
  270. for (SubNet s : controller.getSimManager().getSubNets()) {
  271. if (model.getSubNetColors().size() - 1 < i) {
  272. controller.addSubNetColor(new Color((int) (Math.random() * 255), (int) (Math.random() * 255),
  273. (int) (Math.random() * 255)));
  274. }
  275. for (HolonObject cps : s.getObjects()) {
  276. cps.setBorderColor(model.getSubNetColors().get(i));
  277. }
  278. i++;
  279. }
  280. // drawEdges that is being dragged
  281. if (drawEdge) {
  282. g2.setColor(Color.BLACK);
  283. g2.setStroke(new BasicStroke(2));
  284. // If TempCps is an outside Object
  285. if (!upperNode.getNodes().contains(tempCps)) {
  286. int count = 0;
  287. for (CpsEdge e : upperNode.getConnections()) {
  288. if (e.getA().equals(tempCps)) {
  289. g2.drawLine(borderPos >> 1, (int) (model.getScaleDiv2() + scalediv20 + 5
  290. + (model.getScale() + scalediv20 + 10) * count), x, y);
  291. } else if (e.getB().equals(tempCps)) {
  292. g2.drawLine(borderPos >> 1, (int) (model.getScaleDiv2() + scalediv20 + 5
  293. + (model.getScale() + scalediv20 + 10) * count), x, y);
  294. }
  295. count++;
  296. }
  297. } else {
  298. g2.drawLine(tempCps.getPosition().x + controller.getScaleDiv2(),
  299. tempCps.getPosition().y + controller.getScaleDiv2(), x, y);
  300. }
  301. }
  302. for (CpsEdge con : upperNode.getNodeEdges()) {
  303. if (con.getA().getID() != model.getSelectedObjectID() && con.getB().getID() != model.getSelectedObjectID()
  304. && con != edgeHighlight) {
  305. if (con.getState()) {
  306. g2.setColor(Color.GREEN);
  307. if (con.getCapacity() != -1) {
  308. g2.setStroke(new BasicStroke(Math.min((con.getFlow() / con.getCapacity() * 4), 4)));
  309. }
  310. } else {
  311. g2.setColor(Color.RED);
  312. g2.setStroke(new BasicStroke(2));
  313. }
  314. g2.drawLine(con.getA().getPosition().x + controller.getScaleDiv2(),
  315. con.getA().getPosition().y + controller.getScaleDiv2(),
  316. con.getB().getPosition().x + controller.getScaleDiv2(),
  317. con.getB().getPosition().y + controller.getScaleDiv2());
  318. if (con.getCapacity() == -1) {
  319. maxCap = Character.toString('\u221e');
  320. } else {
  321. maxCap = String.valueOf(con.getCapacity());
  322. }
  323. if (showedInformation[0]) {
  324. g2.drawString(con.getFlow() + "/" + maxCap,
  325. (con.getA().getPosition().x + con.getB().getPosition().x) / 2 + controller.getScaleDiv2(),
  326. (con.getA().getPosition().y + con.getB().getPosition().y) / 2 + controller.getScaleDiv2());
  327. }
  328. }
  329. }
  330. // Highlighted Edge
  331. if (model.getSelectedObjectID() > 0 || !model.getSelectedCpsObjects().isEmpty() || !tempSelected.isEmpty()) {
  332. g2.setColor(Color.BLUE);
  333. for (CpsEdge con : upperNode.getNodeEdges()) {
  334. if (con.getFlow() <= con.getCapacity()) {
  335. g2.setStroke(new BasicStroke(Math.min((con.getFlow() / con.getCapacity() * 4), 4)));
  336. } else {
  337. g2.setStroke(new BasicStroke(2));
  338. }
  339. if (con.getA().getID() == model.getSelectedObjectID()
  340. || model.getSelectedCpsObjects().contains(con.getA()) || tempSelected.contains(con.getA())
  341. || con.getB().getID() == model.getSelectedObjectID()
  342. || model.getSelectedCpsObjects().contains(con.getB())
  343. || tempSelected.contains(con.getB()) && con != edgeHighlight) {
  344. g2.drawLine(con.getA().getPosition().x + controller.getScaleDiv2(),
  345. con.getA().getPosition().y + controller.getScaleDiv2(),
  346. con.getB().getPosition().x + controller.getScaleDiv2(),
  347. con.getB().getPosition().y + controller.getScaleDiv2());
  348. if (con.getCapacity() == -1) {
  349. maxCap = Character.toString('\u221e');
  350. } else {
  351. maxCap = String.valueOf(con.getCapacity());
  352. }
  353. if (showedInformation[0]) {
  354. g2.drawString(con.getFlow() + "/" + maxCap,
  355. (con.getA().getPosition().x + con.getB().getPosition().x) / 2
  356. + controller.getScaleDiv2(),
  357. (con.getA().getPosition().y + con.getB().getPosition().y) / 2
  358. + controller.getScaleDiv2());
  359. }
  360. }
  361. }
  362. } else if (edgeHighlight != null) {
  363. g2.setColor(Color.BLUE);
  364. if (edgeHighlight.getFlow() <= edgeHighlight.getCapacity()) {
  365. g2.setStroke(new BasicStroke(Math.min((edgeHighlight.getFlow() / edgeHighlight.getCapacity() * 4), 4)));
  366. } else {
  367. g2.setStroke(new BasicStroke(2));
  368. }
  369. g2.drawLine(edgeHighlight.getA().getPosition().x + controller.getScaleDiv2(),
  370. edgeHighlight.getA().getPosition().y + controller.getScaleDiv2(),
  371. edgeHighlight.getB().getPosition().x + controller.getScaleDiv2(),
  372. edgeHighlight.getB().getPosition().y + controller.getScaleDiv2());
  373. if (edgeHighlight.getCapacity() == -1) {
  374. maxCap = Character.toString('\u221e');
  375. } else {
  376. maxCap = String.valueOf(edgeHighlight.getCapacity());
  377. }
  378. if (showedInformation[0]) {
  379. g2.drawString(edgeHighlight.getFlow() + "/" + maxCap,
  380. (edgeHighlight.getA().getPosition().x + edgeHighlight.getB().getPosition().x) / 2
  381. + controller.getScaleDiv2(),
  382. (edgeHighlight.getA().getPosition().y + edgeHighlight.getB().getPosition().y) / 2
  383. + controller.getScaleDiv2());
  384. }
  385. }
  386. // Objects in upper node
  387. for (AbstractCpsObject cps : upperNode.getNodes()) {
  388. // Border Highlighting
  389. g2.setColor(cps.getBorderColor());
  390. if (g2.getColor() != Color.WHITE) {
  391. g2.fillRect((int) (cps.getPosition().x - scalediv20 - 3), (int) (cps.getPosition().y - scalediv20 - 3),
  392. (int) (controller.getScale() + ((scalediv20 + 3) * 2)),
  393. (int) (controller.getScale() + ((scalediv20 + 3) * 2)));
  394. }
  395. // node image
  396. if (cps instanceof CpsNode && (cps == tempCps || model.getSelectedCpsObject() == cps
  397. || model.getSelectedCpsObjects().contains(cps) || tempSelected.contains(cps))) {
  398. img = new ImageIcon(this.getClass().getResource("/Images/node_selected.png")).getImage();
  399. } else {
  400. if (cps instanceof HolonSwitch) {
  401. if (((HolonSwitch) cps).getActiveAt()[model.getCurIteration()]) {
  402. ((HolonSwitch) cps).setAutoState(true);
  403. } else {
  404. ((HolonSwitch) cps).setAutoState(false);
  405. }
  406. }
  407. // Highlighting
  408. if ((cps == tempCps && model.getSelectedCpsObjects().size() == 0 && tempSelected.size() == 0)
  409. || model.getSelectedCpsObjects().contains(cps) || tempSelected.contains(cps)) {
  410. g2.setColor(Color.BLUE);
  411. g2.fillRect((int) (cps.getPosition().x - scalediv20), (int) (cps.getPosition().y - scalediv20),
  412. (int) (controller.getScale() + (scalediv20 * 2)),
  413. (int) (controller.getScale() + (scalediv20 * 2)));
  414. if (showedInformation[1] && cps instanceof HolonObject) {
  415. g2.setColor(Color.BLACK);
  416. float totalEnergy = ((HolonObject) cps).getCurrentEnergyAtTimeStep(model.getCurIteration());
  417. g2.drawString(Float.toString(totalEnergy), cps.getPosition().x, cps.getPosition().y - 10);
  418. }
  419. } else if (cps instanceof HolonObject) {
  420. g2.setColor(((HolonObject) cps).getColor());
  421. g2.fillRect((int) (cps.getPosition().x - scalediv20), (int) (cps.getPosition().y - scalediv20),
  422. (int) (controller.getScale() + (scalediv20 * 2)),
  423. (int) (controller.getScale() + (scalediv20 * 2)));
  424. if (showedInformation[1]) {
  425. g2.setColor(Color.BLACK);
  426. float totalEnergy = ((HolonObject) cps).getCurrentEnergyAtTimeStep(model.getCurIteration());
  427. g2.drawString(Float.toString(totalEnergy), cps.getPosition().x, cps.getPosition().y - 10);
  428. }
  429. }
  430. // draw image
  431. File checkPath = new File(cps.getImage());
  432. if (checkPath.exists()) {
  433. img = new ImageIcon(cps.getImage()).getImage();
  434. } else {
  435. img = new ImageIcon(this.getClass().getResource(cps.getImage())).getImage();
  436. }
  437. }
  438. g2.drawImage(img, cps.getPosition().x, cps.getPosition().y, controller.getScale(), controller.getScale(),
  439. null);
  440. }
  441. // Objects connected to upperNode
  442. int count = 0;
  443. for (CpsEdge e : upperNode.getConnections()) {
  444. AbstractCpsObject cps;
  445. if (e.getA().equals(this.upperNode)) {
  446. cps = e.getB();
  447. } else {
  448. cps = e.getA();
  449. }
  450. // Show and Highlight
  451. if (model.getSelectedCpsObjects().contains(cps)) {
  452. for (CpsEdge ed : cps.getConnections()) {
  453. AbstractCpsObject obj = null;
  454. if (upperNode.getNodes().contains(ed.getA())) {
  455. obj = ed.getA();
  456. } else if (upperNode.getNodes().contains(ed.getB())) {
  457. obj = ed.getB();
  458. }
  459. if (obj != null) {
  460. g2.setColor(Color.BLUE);
  461. g2.drawLine(obj.getPosition().x + model.getScaleDiv2(),
  462. obj.getPosition().y + model.getScaleDiv2(), (borderPos >> 1),
  463. (int) (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count)
  464. + model.getScaleDiv2());
  465. }
  466. }
  467. }
  468. // Border Highlighting
  469. g2.setColor(cps.getBorderColor());
  470. if (g2.getColor() != Color.WHITE) {
  471. g2.fillRect((int) ((borderPos >> 1) - model.getScaleDiv2() - scalediv20) - 3,
  472. (int) (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count - scalediv20) - 3,
  473. (int) (controller.getScale() + ((scalediv20 + 3) * 2)),
  474. (int) (controller.getScale() + ((scalediv20 + 3) * 2)));
  475. }
  476. // node image
  477. if (cps instanceof CpsNode && (cps == tempCps || model.getSelectedCpsObject() == cps
  478. || model.getSelectedCpsObjects().contains(cps) || tempSelected.contains(cps))) {
  479. img = new ImageIcon(this.getClass().getResource("/Images/node_selected.png")).getImage();
  480. } else {
  481. if (cps instanceof HolonSwitch) {
  482. if (((HolonSwitch) cps).getActiveAt()[model.getCurIteration()]) {
  483. ((HolonSwitch) cps).setAutoState(true);
  484. } else {
  485. ((HolonSwitch) cps).setAutoState(false);
  486. }
  487. }
  488. // Highlighting
  489. if ((cps == tempCps && model.getSelectedCpsObjects().size() == 0 && tempSelected.size() == 0)
  490. || model.getSelectedCpsObjects().contains(cps) || tempSelected.contains(cps)) {
  491. g2.setColor(Color.BLUE);
  492. g2.fillRect((int) ((borderPos >> 1) - model.getScaleDiv2() - scalediv20),
  493. (int) (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count - scalediv20),
  494. (int) (controller.getScale() + (scalediv20 * 2)),
  495. (int) (controller.getScale() + (scalediv20 * 2)));
  496. } else if (cps instanceof HolonObject) {
  497. g2.setColor(((HolonObject) cps).getColor());
  498. g2.fillRect((int) ((borderPos >> 1) - model.getScaleDiv2() - scalediv20),
  499. (int) (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count - scalediv20),
  500. (int) (controller.getScale() + (scalediv20 * 2)),
  501. (int) (controller.getScale() + (scalediv20 * 2)));
  502. }
  503. // draw image
  504. File checkPath = new File(cps.getImage());
  505. if (checkPath.exists()) {
  506. img = new ImageIcon(cps.getImage()).getImage();
  507. } else {
  508. img = new ImageIcon(this.getClass().getResource(cps.getImage())).getImage();
  509. }
  510. }
  511. g2.drawImage(img, (borderPos >> 1) - model.getScaleDiv2(),
  512. (int) (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count), controller.getScale(),
  513. controller.getScale(), null);
  514. count++;
  515. }
  516. // Dragg Highlighting
  517. g2.setStroke(new BasicStroke(1));
  518. if (doMark) {
  519. g2.setColor(Color.BLACK);
  520. if (sx > x && sy > y) {
  521. g2.drawRect(x, y, sx - x, sy - y);
  522. } else if (sx < x && sy < y) {
  523. g2.drawRect(sx, sy, x - sx, y - sy);
  524. } else if (sx >= x) {
  525. g2.drawRect(x, sy, sx - x, y - sy);
  526. } else if (sy >= y) {
  527. g2.drawRect(sx, y, x - sx, sy - y);
  528. }
  529. }
  530. // Border Line
  531. g2.setColor(Color.BLACK);
  532. g2.drawLine(borderPos, 0, borderPos, this.getHeight());
  533. }
  534. @Override
  535. public void mouseClicked(MouseEvent e) {
  536. }
  537. @Override
  538. public void mouseEntered(MouseEvent e) {
  539. }
  540. @Override
  541. public void mouseExited(MouseEvent e) {
  542. }
  543. @Override
  544. public void mousePressed(MouseEvent e) {
  545. tempCps = null;
  546. dataSelected = null;
  547. edgeHighlight = null;
  548. controller.setSelecteEdge(null);
  549. // Object Selection
  550. if (e.getX() > borderPos) {
  551. for (AbstractCpsObject cps : upperNode.getNodes()) {
  552. cx = cps.getPosition().x;
  553. cy = cps.getPosition().y;
  554. if (x - controller.getScale() <= cx && y - controller.getScale() <= cy && x >= cx && y >= cy) {
  555. tempCps = cps;
  556. controller.addTextToConsole("Selected: ", Color.BLACK, 12, false, false, false);
  557. controller.addTextToConsole("" + cps.getName(), Color.BLUE, 12, true, false, false);
  558. controller.addTextToConsole(", ID:", Color.BLACK, 12, false, false, false);
  559. controller.addTextToConsole("" + cps.getID(), Color.RED, 12, true, false, true);
  560. dragging = true;
  561. if (e.isControlDown() && tempCps != null) {
  562. System.out.println(tempCps.getName() + " " + tempCps.getID());
  563. if (model.getSelectedCpsObjects().contains(tempCps)) {
  564. controller.deleteSelectedObject(tempCps);
  565. } else {
  566. controller.addSelectedObject(tempCps);
  567. }
  568. } else {
  569. System.out.println("HEre");
  570. controller.setSelectedObjectID(tempCps.getID());
  571. model.getSelectedCpsObjects().clear();
  572. controller.addSelectedObject(tempCps);
  573. }
  574. // If drawing an Edge (CTRL down)
  575. if (tempCps.getClass() == HolonObject.class) {
  576. HolonObject tempObj = ((HolonObject) tempCps);
  577. dataSelected = tempObj.getElements();
  578. }
  579. if (e.isShiftDown()) {
  580. drawEdge = true;
  581. dragging = false;
  582. }
  583. break;
  584. }
  585. }
  586. } else {
  587. // look for objects connected to uppernode
  588. int count = 0;
  589. for (CpsEdge ed : upperNode.getConnections()) {
  590. AbstractCpsObject cps;
  591. if (ed.getA().equals(this.upperNode)) {
  592. cps = ed.getB();
  593. } else {
  594. cps = ed.getA();
  595. }
  596. if (x - controller.getScale() <= ((borderPos >> 1) - model.getScaleDiv2())
  597. && y - controller.getScale() <= (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count)
  598. && x >= (borderPos >> 1) - model.getScaleDiv2()
  599. && y >= (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count)) {
  600. tempCps = cps;
  601. controller.addTextToConsole("Selected: ", Color.BLACK, 12, false, false, false);
  602. controller.addTextToConsole("" + cps.getName(), Color.BLUE, 12, true, false, false);
  603. controller.addTextToConsole(", ID:", Color.BLACK, 12, false, false, false);
  604. controller.addTextToConsole("" + cps.getID(), Color.RED, 12, true, false, true);
  605. controller.setSelectedObjectID(tempCps.getID());
  606. // If drawing an Edge (CTRL down)
  607. if (tempCps.getClass() == HolonObject.class) {
  608. HolonObject tempObj = ((HolonObject) tempCps);
  609. dataSelected = tempObj.getElements();
  610. }
  611. if (e.isShiftDown()) {
  612. drawEdge = true;
  613. }
  614. }
  615. count++;
  616. }
  617. }
  618. if (e.isControlDown() && tempCps != null) {
  619. if (model.getSelectedCpsObjects().contains(tempCps)) {
  620. controller.deleteSelectedObject(tempCps);
  621. } else {
  622. controller.addSelectedObject(tempCps);
  623. }
  624. }
  625. // Selection of CpsObject
  626. // model.setSelectedCpsObject(tempCps);
  627. // Edge Selection
  628. if (tempCps == null) {
  629. edgeHighlight = mousePositionOnEdge(x, y);
  630. controller.setSelecteEdge(edgeHighlight);
  631. controller.setSelectedObjectID(0);
  632. if (!e.isControlDown() && e.getButton() != MouseEvent.BUTTON3) {
  633. model.getSelectedCpsObjects().clear();
  634. }
  635. updCon.deleteRows(model.getMultiTable());
  636. updCon.deleteRows(model.getSingleTable());
  637. }
  638. if (edgeHighlight == null && tempCps == null) {
  639. sx = e.getX();
  640. sy = e.getY();
  641. doMark = true;
  642. }
  643. for (AbstractCpsObject temp : model.getSelectedCpsObjects()) {
  644. System.out.println(temp.getName() + " " + temp.getID());
  645. }
  646. System.out.println("");
  647. updCon.refreshTableHolonElement(model.getMultiTable(), model.getSingleTable());
  648. updCon.refreshTableProperties(model.getPropertyTable());
  649. repaint();
  650. }
  651. @Override
  652. public void mouseReleased(MouseEvent e) {
  653. dragging = false;
  654. if (drawEdge) {
  655. drawEdge = false;
  656. drawDeleteEdge();
  657. }
  658. if (dragged == true) {
  659. try {
  660. controller.autoSave();
  661. } catch (IOException ex) {
  662. // TODO Auto-generated catch block
  663. ex.printStackTrace();
  664. }
  665. }
  666. if (!e.isControlDown() && dragged == false && tempCps != null && e.BUTTON3 != e.getButton()) {
  667. model.getSelectedCpsObjects().clear();
  668. controller.addSelectedObject(tempCps);
  669. }
  670. dragged = false;
  671. // Rightclick List
  672. if (e.getButton() == MouseEvent.BUTTON3) {
  673. if (e.getButton() == MouseEvent.BUTTON3 && tempCps != null) {
  674. itemDelete.setEnabled(true);
  675. itemCut.setEnabled(true);
  676. itemCopy.setEnabled(true);
  677. if (tempCps != null)
  678. itemGroup.setEnabled(true);
  679. if (tempCps instanceof CpsUpperNode)
  680. itemUngroup.setEnabled(true);
  681. else
  682. itemUngroup.setEnabled(false);
  683. if (!(tempCps instanceof HolonSwitch)) {
  684. itemTrack.setEnabled(true);
  685. itemUntrack.setEnabled(true);
  686. } else {
  687. itemTrack.setEnabled(false);
  688. itemUntrack.setEnabled(false);
  689. }
  690. if (model.getSelectedCpsObjects().size() == 0) {
  691. controller.addSelectedObject(tempCps);
  692. }
  693. } else {
  694. itemCut.setEnabled(false);
  695. itemCopy.setEnabled(false);
  696. itemDelete.setEnabled(false);
  697. itemGroup.setEnabled(false);
  698. itemUngroup.setEnabled(false);
  699. itemTrack.setEnabled(false);
  700. itemUntrack.setEnabled(false);
  701. }
  702. mousePosition = this.getMousePosition();
  703. popmenu.show(e.getComponent(), e.getX(), e.getY());
  704. }
  705. if (doMark) {
  706. doMark = false;
  707. for (AbstractCpsObject cps : tempSelected) {
  708. if (!model.getSelectedCpsObjects().contains(cps)) {
  709. controller.addSelectedObject(cps);
  710. }
  711. }
  712. tempSelected.clear();
  713. }
  714. if (doubleClick() && tempCps != null && tempCps instanceof HolonSwitch) {
  715. ((HolonSwitch) tempCps).switchState();
  716. }
  717. controller.calculateStateForTimeStep(model.getCurIteration());
  718. repaint();
  719. }
  720. @Override
  721. public void mouseDragged(MouseEvent e) {
  722. // If Edge is drawn
  723. x = e.getX();
  724. y = e.getY();
  725. if (!model.getSelectedCpsObjects().contains(tempCps) && doMark == false) {
  726. model.getSelectedCpsObjects().clear();
  727. if (tempCps != null) {
  728. controller.addSelectedObject(tempCps);
  729. }
  730. }
  731. if (dragging) {
  732. try {
  733. if (upperNode.getNodes().contains(tempCps)) {
  734. dragged = true;
  735. float xDist, yDist; // Distance
  736. x = e.getX() - controller.getScaleDiv2();
  737. y = e.getY() - controller.getScaleDiv2();
  738. // tempCps in the upperNode? if not its a connected Object
  739. // from
  740. // outside
  741. // Make sure its in bounds
  742. if (e.getX() < controller.getScaleDiv2() + borderPos + 5)
  743. x = borderPos + 5;
  744. else if (e.getX() > this.getWidth() - controller.getScaleDiv2())
  745. x = this.getWidth() - controller.getScale();
  746. if (e.getY() < controller.getScaleDiv2())
  747. y = 0;
  748. else if (e.getY() > this.getHeight() - controller.getScaleDiv2())
  749. y = this.getHeight() - controller.getScale();
  750. // Distance
  751. xDist = x - tempCps.getPosition().x;
  752. yDist = y - tempCps.getPosition().y;
  753. tempCps.setPosition(x, y); // Drag Position
  754. // TipText Position and name
  755. objectTT.setTipText(tempCps.getName() + ", " + tempCps.getID());
  756. objectTT.setLocation(x, y + controller.getScale());
  757. // All Selected Objects
  758. for (AbstractCpsObject cps : model.getSelectedCpsObjects()) {
  759. if (cps != tempCps) {
  760. x = (int) (cps.getPosition().x + xDist);
  761. y = (int) (cps.getPosition().y + yDist);
  762. // Make sure its in bounds
  763. if (x < borderPos + 5)
  764. x = borderPos + 5;
  765. else if (x > this.getWidth() - controller.getScale())
  766. x = this.getWidth() - controller.getScale();
  767. if (y <= 0)
  768. y = 0;
  769. else if (y > this.getHeight() - controller.getScale())
  770. y = this.getHeight() - controller.getScale();
  771. cps.setPosition(x, y);
  772. }
  773. }
  774. }
  775. repaint();
  776. } catch (Exception eex) {
  777. }
  778. }
  779. // Mark Objects
  780. if (doMark) {
  781. tempSelected.clear();
  782. for (AbstractCpsObject cps : upperNode.getNodes()) {
  783. int x1 = sx, x2 = x, y1 = sy, y2 = y;
  784. if (sx >= x) {
  785. x1 = x;
  786. x2 = sx;
  787. }
  788. if (sy >= y) {
  789. y1 = y;
  790. y2 = sy;
  791. }
  792. if (x1 <= cps.getPosition().x + model.getScaleDiv2() && y1 <= cps.getPosition().y + model.getScaleDiv2()
  793. && x2 >= cps.getPosition().x + model.getScaleDiv2()
  794. && y2 >= cps.getPosition().y + model.getScaleDiv2()) {
  795. tempSelected.add(cps);
  796. }
  797. }
  798. int count = 0;
  799. for (CpsEdge ed : upperNode.getConnections()) {
  800. AbstractCpsObject cps = null;
  801. if (ed.getA().equals(upperNode)) {
  802. cps = ed.getB();
  803. } else {
  804. cps = ed.getA();
  805. }
  806. int x1 = sx, x2 = x, y1 = sy, y2 = y;
  807. if (sx >= x) {
  808. x1 = x;
  809. x2 = sx;
  810. }
  811. if (sy >= y) {
  812. y1 = y;
  813. y2 = sy;
  814. }
  815. if (x1 <= borderPos >> 1
  816. && y1 <= (int) (5 + (model.getScale() + scalediv20 + 10) * count) + model.getScaleDiv2()
  817. && x2 >= borderPos >> 1 && y2 >= (int) (5 + (model.getScale() + scalediv20 + 10) * count)) {
  818. tempSelected.add(cps);
  819. }
  820. count++;
  821. }
  822. }
  823. repaint();
  824. }
  825. @Override
  826. public void mouseMoved(MouseEvent e) {
  827. x = e.getX();
  828. y = e.getY();
  829. // Everytghing for the tooltip :)
  830. boolean on = false;
  831. for (AbstractCpsObject cps : upperNode.getNodes()) {
  832. cx = cps.getPosition().x;
  833. cy = cps.getPosition().y;
  834. if (x - controller.getScale() <= cx && y - controller.getScale() <= cy && x >= cx && y >= cy) {
  835. objectTT.setLocation(cx, cy + controller.getScale());
  836. objectTT.setTipText(cps.getName() + ", " + cps.getID());
  837. on = true;
  838. }
  839. }
  840. int count = 0;
  841. for (CpsEdge ed : upperNode.getConnections()) {
  842. AbstractCpsObject cps;
  843. if (ed.getA().equals(this.upperNode)) {
  844. cps = ed.getB();
  845. } else {
  846. cps = ed.getA();
  847. }
  848. cx = borderPos >> 1;
  849. cy = (int) (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count);
  850. if (x - controller.getScale() <= cx && y - controller.getScale() <= cy && x >= cx && y >= cy) {
  851. objectTT.setLocation(cx - model.getScaleDiv2(), cy + controller.getScale());
  852. objectTT.setTipText(cps.getName() + ", " + cps.getID());
  853. on = true;
  854. }
  855. count++;
  856. }
  857. if (!on) {
  858. objectTT.setTipText("");
  859. // objectTT.setLocation(-200, -200);
  860. }
  861. }
  862. /**
  863. * Draws or Deletes an Edge.
  864. */
  865. private void drawDeleteEdge() {
  866. boolean node = true; // new node?
  867. boolean newEdge = true;
  868. boolean onEdge = true;
  869. boolean deleteNode = false;
  870. boolean outsideCon = !upperNode.getNodes().contains(tempCps); // Connection
  871. // to
  872. // the
  873. // outside
  874. boolean found = false;
  875. CpsEdge e = null;
  876. AbstractCpsObject tempCPS = null;
  877. for (AbstractCpsObject cps : upperNode.getNodes()) {
  878. cx = cps.getPosition().x;
  879. cy = cps.getPosition().y;
  880. if (x - controller.getScale() <= cx && y - controller.getScale() <= cy && x >= cx && y >= cy
  881. && cps != tempCps) {
  882. found = true;
  883. node = false;
  884. onEdge = false;
  885. for (CpsEdge p : tempCps.getConnections()) {
  886. if ((p.getA() == tempCps && p.getB() == cps) || (p.getB() == tempCps && p.getA() == cps)) {
  887. newEdge = false;
  888. e = p;
  889. }
  890. }
  891. if (!newEdge) {
  892. if (outsideCon) {
  893. controller.disconnectNodes(e, upperNode);
  894. } else {
  895. controller.delEdgeUpperNode(e, upperNode);
  896. }
  897. // Node ohne Edge?
  898. if (e.getA().getClass() == CpsNode.class && e.getA().getConnections().isEmpty()) {
  899. tempCps = e.getA();
  900. deleteNode = true;
  901. }
  902. if (e.getB().getClass() == CpsNode.class && e.getB().getConnections().isEmpty()) {
  903. tempCPS = e.getB();
  904. deleteNode = true;
  905. }
  906. }
  907. if (newEdge) {
  908. e = new CpsEdge(cps, tempCps, model.getMaxCapacity());
  909. if (outsideCon) {
  910. controller.connectNodes(e, upperNode);
  911. } else {
  912. controller.addEdgeUpperNode(e, upperNode);
  913. }
  914. }
  915. }
  916. }
  917. if (!found) {
  918. int count = 0;
  919. for (CpsEdge ed : upperNode.getConnections()) {
  920. AbstractCpsObject cps = null;
  921. if (ed.getA().equals(upperNode)) {
  922. cps = ed.getB();
  923. } else {
  924. cps = ed.getA();
  925. }
  926. cx = borderPos >> 1;
  927. cy = (int) (scalediv20 + 5 + (model.getScale() + scalediv20 + 10) * count);
  928. if (x - controller.getScale() <= cx && y - controller.getScale() <= cy && x >= cx && y >= cy
  929. && cps != tempCps) {
  930. outsideCon = true;
  931. node = false;
  932. onEdge = false;
  933. for (CpsEdge p : tempCps.getConnections()) {
  934. if ((p.getA() == tempCps && p.getB() == cps) || (p.getB() == tempCps && p.getA() == cps)) {
  935. newEdge = false;
  936. e = p;
  937. }
  938. }
  939. if (!newEdge) {
  940. if (outsideCon) {
  941. controller.disconnectNodes(e, upperNode);
  942. } else {
  943. controller.delEdgeUpperNode(e, upperNode);
  944. }
  945. // Node ohne Edge?
  946. if (e.getA().getClass() == CpsNode.class && e.getA().getConnections().isEmpty()) {
  947. tempCps = e.getA();
  948. deleteNode = true;
  949. }
  950. if (e.getB().getClass() == CpsNode.class && e.getB().getConnections().isEmpty()) {
  951. tempCPS = e.getB();
  952. deleteNode = true;
  953. }
  954. }
  955. if (newEdge) {
  956. CpsEdge edge = new CpsEdge(cps, tempCps, model.getMaxCapacity());
  957. if (outsideCon) {
  958. controller.connectNodes(edge, upperNode);
  959. } else {
  960. controller.addEdgeUpperNode(edge, upperNode);
  961. }
  962. }
  963. }
  964. count++;
  965. }
  966. }
  967. // Edge auf eine Edge gezogen?
  968. if (onEdge) {
  969. CpsEdge p = mousePositionOnEdge(x, y);
  970. if (p != null) {
  971. CpsEdge e1 = null;
  972. CpsEdge e2 = null;
  973. node = false;
  974. CpsNode n = new CpsNode("Node");
  975. n.setPosition(x - model.getScaleDiv2(), y - model.getScaleDiv2());
  976. controller.addObjUpperNode(n, upperNode);
  977. AbstractCpsObject r, k;
  978. r = p.getA();
  979. k = p.getB();
  980. e = new CpsEdge(n, tempCps, model.getMaxCapacity());
  981. e1 = new CpsEdge(n, r, model.getMaxCapacity());
  982. e2 = new CpsEdge(n, k, model.getMaxCapacity());
  983. controller.delEdgeUpperNode(p, upperNode);
  984. if (outsideCon) {
  985. controller.connectNodes(e, upperNode);
  986. } else {
  987. controller.addEdgeUpperNode(e, upperNode);
  988. }
  989. controller.addEdgeUpperNode(e1, upperNode);
  990. controller.addEdgeUpperNode(e2, upperNode);
  991. }
  992. }
  993. // ins leere Gedragged
  994. if (node && x > borderPos) {
  995. CpsNode n = new CpsNode("Node");
  996. n.setPosition(x - model.getScaleDiv2(), y - model.getScaleDiv2());
  997. controller.addObjUpperNode(n, upperNode);
  998. e = new CpsEdge(n, tempCps, model.getMaxCapacity());
  999. if (outsideCon) {
  1000. controller.connectNodes(e, upperNode);
  1001. } else {
  1002. controller.addEdgeUpperNode(e, upperNode);
  1003. }
  1004. }
  1005. // Wenn ein Node ohne Connections da ist
  1006. if (deleteNode) {
  1007. controller.delCanvasObject(tempCps);
  1008. tempCps = null;
  1009. }
  1010. }
  1011. /**
  1012. * Checks if the mouse is on an Edge.
  1013. *
  1014. * @param x
  1015. * Position of the Mouse
  1016. * @param y
  1017. * Position of the Mouse
  1018. *
  1019. * @return CpsEdge the Mouse is on, null if the mouse is not on an Edge
  1020. */
  1021. public CpsEdge mousePositionOnEdge(int x, int y) {
  1022. int lx, ly, hx, hy;
  1023. for (CpsEdge p : upperNode.getNodeEdges()) {
  1024. Line2D l = new Line2D.Float(p.getA().getPosition().x, p.getA().getPosition().y, p.getB().getPosition().x,
  1025. p.getB().getPosition().y);
  1026. if (p.getA().getPosition().x > p.getB().getPosition().x) {
  1027. hx = p.getA().getPosition().x + model.getScaleDiv2() + 7;
  1028. lx = p.getB().getPosition().x + model.getScaleDiv2() - 7;
  1029. } else {
  1030. lx = p.getA().getPosition().x + model.getScaleDiv2() - 7;
  1031. hx = p.getB().getPosition().x + model.getScaleDiv2() + 7;
  1032. }
  1033. if (p.getA().getPosition().y > p.getB().getPosition().y) {
  1034. hy = p.getA().getPosition().y + model.getScaleDiv2() + 7;
  1035. ly = p.getB().getPosition().y + model.getScaleDiv2() - 7;
  1036. } else {
  1037. ly = p.getA().getPosition().y + model.getScaleDiv2() - 7;
  1038. hy = p.getB().getPosition().y + model.getScaleDiv2() + 7;
  1039. }
  1040. // distance from a point to a line and between both Objects
  1041. if (l.ptLineDistSq(x - model.getScaleDiv2(), y - model.getScaleDiv2()) < 20 && x > lx && x < hx && y > ly
  1042. && y < hy) {
  1043. return p;
  1044. }
  1045. }
  1046. return null;
  1047. }
  1048. /**
  1049. * Checks if a double click was made.
  1050. *
  1051. * @return true if doublecklick, false if not
  1052. */
  1053. private boolean doubleClick() {
  1054. if (click) {
  1055. click = false;
  1056. return true;
  1057. } else {
  1058. click = true;
  1059. Timer t = new Timer("doubleclickTimer", false);
  1060. t.schedule(new TimerTask() {
  1061. @Override
  1062. public void run() {
  1063. click = false;
  1064. }
  1065. }, 500);
  1066. }
  1067. return false;
  1068. }
  1069. /**
  1070. * sets the Edge Capacity.
  1071. *
  1072. * @param cap
  1073. * capacity
  1074. */
  1075. public void setEdgeCapacity(float cap) {
  1076. controller.setMaxCapacity(cap);
  1077. }
  1078. /**
  1079. * Set if Information should be shown.
  1080. *
  1081. * @param connection
  1082. * boolean for conecction
  1083. * @param object
  1084. * boolean for objects
  1085. */
  1086. public void setShowedInformation(boolean connection, boolean object) {
  1087. showedInformation[0] = connection;
  1088. showedInformation[1] = object;
  1089. }
  1090. /**
  1091. * Returns if Information should be shown.
  1092. *
  1093. * @return Array of boolean [0] = connection, [1] = objects
  1094. */
  1095. public boolean[] getShowedInformation() {
  1096. return showedInformation;
  1097. }
  1098. }