Made pin drawing optional
[Mograsim.git] / LogicUI / src / era / mi / gui / LogicUICanvas.java
index d6b32d7..b64b842 100644 (file)
@@ -1,11 +1,14 @@
 package era.mi.gui;\r
 \r
+import java.util.function.Consumer;\r
+\r
 import org.eclipse.swt.SWT;\r
 import org.eclipse.swt.widgets.Composite;\r
 import org.eclipse.swt.widgets.Event;\r
 \r
 import era.mi.gui.model.ViewModel;\r
 import era.mi.gui.model.components.GUIComponent;\r
+import era.mi.gui.model.wires.GUIWire;\r
 import era.mi.gui.model.wires.Pin;\r
 import net.haspamelodica.swt.helper.gcs.GeneralGC;\r
 import net.haspamelodica.swt.helper.swtobjectwrappers.Point;\r
@@ -19,6 +22,8 @@ import net.haspamelodica.swt.helper.zoomablecanvas.ZoomableCanvas;
  */\r
 public class LogicUICanvas extends ZoomableCanvas\r
 {\r
+       private static final boolean DRAW_PINS = false;\r
+\r
        private final ViewModel model;\r
 \r
        public LogicUICanvas(Composite parent, int style, ViewModel model)\r
@@ -27,8 +32,47 @@ public class LogicUICanvas extends ZoomableCanvas
 \r
                this.model = model;\r
 \r
-               model.addComponentAddedListener(c -> redrawThreadsafe());\r
-               model.addWireAddedListener(c -> redrawThreadsafe());\r
+               Consumer<Object> redrawConsumer = o -> redrawThreadsafe();\r
+               Consumer<Pin> pinAddedListener = p ->\r
+               {\r
+                       p.addPinMovedListener(redrawConsumer);\r
+                       redrawThreadsafe();\r
+               };\r
+               Consumer<Pin> pinRemovedListener = p ->\r
+               {\r
+                       p.removePinMovedListener(redrawConsumer);\r
+                       redrawThreadsafe();\r
+               };\r
+               Consumer<? super GUIComponent> componentAddedListener = c ->\r
+               {\r
+                       c.addComponentLookChangedListener(redrawConsumer);\r
+                       c.addComponentMovedListener(redrawConsumer);\r
+                       c.addPinAddedListener(pinAddedListener);\r
+                       c.addPinRemovedListener(pinRemovedListener);\r
+                       redrawThreadsafe();\r
+               };\r
+               model.addComponentAddedListener(componentAddedListener);\r
+               model.getComponents().forEach(componentAddedListener);\r
+               model.addComponentRemovedListener(c ->\r
+               {\r
+                       c.removeComponentLookChangedListener(redrawConsumer);\r
+                       c.removeComponentMovedListener(redrawConsumer);\r
+                       c.removePinAddedListener(pinAddedListener);\r
+                       c.removePinRemovedListener(pinRemovedListener);\r
+                       redrawThreadsafe();\r
+               });\r
+               Consumer<? super GUIWire> wireAddedListener = w ->\r
+               {\r
+                       w.addWireLookChangedListener(redrawConsumer);\r
+                       redrawThreadsafe();\r
+               };\r
+               model.addWireAddedListener(wireAddedListener);\r
+               model.getWires().forEach(wireAddedListener);\r
+               model.addWireRemovedListener(w ->\r
+               {\r
+                       w.removeWireLookChangedListener(redrawConsumer);\r
+                       redrawThreadsafe();\r
+               });\r
 \r
                addZoomedRenderer(gc ->\r
                {\r
@@ -42,11 +86,14 @@ public class LogicUICanvas extends ZoomableCanvas
        private void drawComponent(GeneralGC gc, GUIComponent component, Rectangle visibleRegion)\r
        {\r
                component.render(gc, visibleRegion);\r
-               gc.setBackground(getDisplay().getSystemColor(SWT.COLOR_CYAN));\r
-               for (Pin p : component.getPins())\r
+               if (DRAW_PINS)\r
                {\r
-                       Point pos = p.getPos();\r
-                       gc.fillOval(pos.x - 1, pos.y - 1, 2, 2);\r
+                       gc.setBackground(getDisplay().getSystemColor(SWT.COLOR_DARK_CYAN));\r
+                       for (Pin p : component.getPins())\r
+                       {\r
+                               Point pos = p.getPos();\r
+                               gc.fillOval(pos.x - 1, pos.y - 1, 2, 2);\r
+                       }\r
                }\r
        }\r
 \r