X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=LogicUI%2Fsrc%2Fera%2Fmi%2Fgui%2Fmodel%2Fwires%2FGUIWire.java;h=c2f03ee56d3e3430ede18856d0eb952ad687448b;hb=e618fa725540dd5f92ccf0ed7d65acdc8eb83f93;hp=8ecf1c459309751a50a7ffc0b5e2483119bbb1fa;hpb=ba9a2b22b7b87e06a5ad7d8a2050c2d8298aa66b;p=Mograsim.git diff --git a/LogicUI/src/era/mi/gui/model/wires/GUIWire.java b/LogicUI/src/era/mi/gui/model/wires/GUIWire.java index 8ecf1c45..c2f03ee5 100644 --- a/LogicUI/src/era/mi/gui/model/wires/GUIWire.java +++ b/LogicUI/src/era/mi/gui/model/wires/GUIWire.java @@ -1,11 +1,13 @@ package era.mi.gui.model.wires; -import org.eclipse.swt.SWT; -import org.eclipse.swt.graphics.Color; +import java.util.ArrayList; +import java.util.List; +import java.util.function.Consumer; +import era.mi.gui.ColorHelper; import era.mi.gui.model.ViewModel; -import era.mi.logic.types.Bit; -import era.mi.logic.wires.Wire; +import era.mi.logic.types.BitVectorFormatter; +import era.mi.logic.wires.Wire.ReadEnd; import net.haspamelodica.swt.helper.gcs.GeneralGC; import net.haspamelodica.swt.helper.swtobjectwrappers.Point; @@ -16,7 +18,9 @@ public class GUIWire private Pin pin2; private double[] path; - private Wire wire; + private final List> wireChangedListeners; + + private ReadEnd end; public GUIWire(ViewModel model, Pin pin1, Pin pin2, Point... path) { @@ -31,6 +35,8 @@ public class GUIWire this.pin1 = pin1; this.pin2 = pin2; + wireChangedListeners = new ArrayList<>(); + pin1.addPinMovedListener(p -> pin1Moved()); pin2.addPinMovedListener(p -> pin2Moved()); pin1Moved(); @@ -60,40 +66,21 @@ public class GUIWire public void render(GeneralGC gc) { - Color oldFG = gc.getForeground(); - gc.setForeground(gc.getDevice().getSystemColor(getSWTColorConstantForWire(wire))); - gc.drawPolyline(path); - gc.setForeground(oldFG); + ColorHelper.executeWithDifferentForeground(gc, BitVectorFormatter.formatAsColor(end), () -> gc.drawPolyline(path)); } - public void setLogicModelWire(Wire wire) + public void setLogicModelBinding(ReadEnd end) { - this.wire = wire; + this.end = end; + end.addObserver((i, o) -> callWireChangedListeners()); } - public static int getSWTColorConstantForWire(Wire wire) - { - if (wire != null && wire.length == 1) - return getSWTColorConstantForBit(wire.getValue()); - else - return SWT.COLOR_BLACK; - } + // @formatter:off + public void addWireChangedListener (Consumer listener) {wireChangedListeners.add (listener);} + + public void removeWireChangedListener(Consumer listener) {wireChangedListeners.remove(listener);} + + private void callWireChangedListeners() {wireChangedListeners.forEach(l -> l.accept(this));} + // @formatter:on - public static int getSWTColorConstantForBit(Bit bit) - { - switch (bit) - { - case ONE: - return SWT.COLOR_GREEN; - case ZERO: - return SWT.COLOR_BLUE; - case Z: - return SWT.COLOR_BLACK; - case U: - case X: - return SWT.COLOR_RED; - default: - throw new IllegalArgumentException("Unknown enum constant: " + bit); - } - } } \ No newline at end of file