UpperNodeCanvas.java 51 KB

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