From: Daniel Kirschten Date: Thu, 16 May 2019 09:16:08 +0000 (+0200) Subject: GUIManualSwitch now shows the actual value of the output WireArray X-Git-Url: https://mograsim.net/gitweb/?a=commitdiff_plain;h=953ad2ae43cdaf494bfecbf4fe3770c9789f4613;p=Mograsim.git GUIManualSwitch now shows the actual value of the output WireArray --- diff --git a/LogicUI/src/era/mi/gui/components/GUIManualSwitch.java b/LogicUI/src/era/mi/gui/components/GUIManualSwitch.java index 9d58cac9..9c57b9f8 100644 --- a/LogicUI/src/era/mi/gui/components/GUIManualSwitch.java +++ b/LogicUI/src/era/mi/gui/components/GUIManualSwitch.java @@ -2,8 +2,11 @@ package era.mi.gui.components; import java.util.ArrayList; import java.util.Collections; +import java.util.HashMap; import java.util.List; +import java.util.Map; +import era.mi.logic.Bit; import era.mi.logic.components.ManualSwitch; import era.mi.logic.wires.WireArray; import net.haspamelodica.swt.helper.gcs.GeneralGC; @@ -13,6 +16,19 @@ import net.haspamelodica.swt.helper.swtobjectwrappers.Rectangle; public class GUIManualSwitch extends ManualSwitch implements BasicGUIComponent { + private static final Map bitNames; + static + { + Map bitNamesModifiable = new HashMap<>(); + bitNamesModifiable.put(Bit.ONE, "1"); + bitNamesModifiable.put(Bit.ZERO, "0"); + bitNamesModifiable.put(Bit.Z, "Z"); + bitNamesModifiable.put(Bit.U, "U"); + bitNamesModifiable.put(Bit.X, "X"); + bitNames = Collections.unmodifiableMap(bitNamesModifiable); + } + + private final WireArray wa; private final List connectedWireArrays; private final List wireArrayConnectionPoints; @@ -20,6 +36,8 @@ public class GUIManualSwitch extends ManualSwitch implements BasicGUIComponent { super(output); + this.wa = output; + List connectedWireArraysModifiable = new ArrayList<>(); List wireArrayConnectionPointsModifiable = new ArrayList<>(); @@ -39,7 +57,7 @@ public class GUIManualSwitch extends ManualSwitch implements BasicGUIComponent public void render(GeneralGC gc) { gc.drawRectangle(0, 0, 20, 15); - String label = isOn() ? "ON" : "OFF"; + String label = bitNames.get(wa.getValue()); Font oldFont = gc.getFont(); Font labelFont = new Font(oldFont.getName(), 6, oldFont.getStyle()); gc.setFont(labelFont);