X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=net.mograsim.logic.ui%2Fsrc%2Fnet%2Fmograsim%2Flogic%2Fui%2Fmodel%2Fcomponents%2Fmi%2Fnandbased%2FGUIand.java;h=018e9bb1b244adb1d9ffa63197c557cb3ec9a452;hb=19ee1a7fdb06a1df65cd7df78fed935124496707;hp=c0a50f36ac2497d692a1eb61b7e687dff3a39dc1;hpb=506435012240652d7a71b8597cc868853409e397;p=Mograsim.git diff --git a/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIand.java b/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIand.java index c0a50f36..018e9bb1 100644 --- a/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIand.java +++ b/net.mograsim.logic.ui/src/net/mograsim/logic/ui/model/components/mi/nandbased/GUIand.java @@ -3,67 +3,43 @@ package net.mograsim.logic.ui.model.components.mi.nandbased; import net.haspamelodica.swt.helper.swtobjectwrappers.Point; import net.mograsim.logic.ui.model.ViewModelModifiable; import net.mograsim.logic.ui.model.components.GUINandGate; -import net.mograsim.logic.ui.model.components.SubmodelComponent; +import net.mograsim.logic.ui.model.components.SimpleRectangularSubmodelComponent; import net.mograsim.logic.ui.model.wires.GUIWire; import net.mograsim.logic.ui.model.wires.Pin; import net.mograsim.logic.ui.model.wires.WireCrossPoint; -public class GUIand extends SubmodelComponent +public class GUIand extends SimpleRectangularSubmodelComponent { - private final Pin pinA; - private final Pin pinB; - private final Pin pinY; - public GUIand(ViewModelModifiable model) { - super(model, "GUIand"); - setSize(35, 25); + super(model, 1, "GUIand"); setSubmodelScale(.4); - - Pin A = addSubmodelInterface(1, 0, 5); - Pin B = addSubmodelInterface(1, 0, 20); - Pin Y = addSubmodelInterface(1, 35, 12.5); - - this.pinA = getSupermodelPin(A); - this.pinB = getSupermodelPin(B); - this.pinY = getSupermodelPin(Y); - - initSubmodelComponents(A, B, Y); + setInputPins("A", "B"); + setOutputPins("Y"); + initSubmodelComponents(); } @SuppressWarnings("unused") // for GUIWires being created - private void initSubmodelComponents(Pin A, Pin B, Pin Y) + private void initSubmodelComponents() { + Pin A = getSubmodelPin("A"); + Pin B = getSubmodelPin("B"); + Pin Y = getSubmodelPin("Y"); + GUINandGate nand = new GUINandGate(submodelModifiable, 1); GUINandGate not = new GUINandGate(submodelModifiable, 1); WireCrossPoint cp1 = new WireCrossPoint(submodelModifiable, 1); - nand.moveTo(20, 21.25); - not.moveTo(50, 21.25); - cp1.moveTo(45, 31.25); - - new GUIWire(submodelModifiable, A, nand.getInputPins().get(0), new Point(10, 12.5), new Point(10, 26.25)); - new GUIWire(submodelModifiable, B, nand.getInputPins().get(1), new Point(10, 50), new Point(10, 36.25)); - new GUIWire(submodelModifiable, nand.getOutputPin(), cp1.getPin()); - new GUIWire(submodelModifiable, cp1.getPin(), not.getInputPins().get(0), new Point(45, 26.25)); - new GUIWire(submodelModifiable, cp1.getPin(), not.getInputPins().get(1), new Point(45, 36.25)); - new GUIWire(submodelModifiable, not.getOutputPin(), Y); - } + nand.moveTo(20, 15); + not.moveTo(50, 15); + cp1.moveCenterTo(45, 25); - public Pin getPinA() - { - return pinA; + new GUIWire(submodelModifiable, A, nand.getPin("A")); + new GUIWire(submodelModifiable, B, nand.getPin("B")); + new GUIWire(submodelModifiable, nand.getPin("Y"), cp1, new Point[0]); + new GUIWire(submodelModifiable, cp1, not.getPin("A"), new Point(45, 20)); + new GUIWire(submodelModifiable, cp1, not.getPin("B"), new Point(45, 30)); + new GUIWire(submodelModifiable, not.getPin("Y"), Y); } - - public Pin getPinB() - { - return pinB; - } - - public Pin getPinY() - { - return pinY; - } - } \ No newline at end of file