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
*/\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
\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
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