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=cb7f6b688795c6340432fbf80cae3ae69d0d57db;hb=ae74a6a022756a4cc7ee5b453ad7a68e13832788;hp=eb8b8880478068f06f18ba395787c136d2227d0a;hpb=f84fb965a1f4dc6d6675445426d4e68aa5b989fb;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 eb8b8880..cb7f6b68 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 = getInputSubmodelPins().get(0); + Pin B = getInputSubmodelPins().get(1); + Pin Y = getOutputSubmodelPins().get(0); + 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); + nand.moveTo(20, 15); + not.moveTo(50, 15); + cp1.moveCenterTo(45, 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); - new GUIWire(submodelModifiable, cp1, not.getInputPins().get(0), new Point(45, 26.25)); - new GUIWire(submodelModifiable, cp1, not.getInputPins().get(1), new Point(45, 36.25)); + new GUIWire(submodelModifiable, A, nand.getInputPins().get(0)); + new GUIWire(submodelModifiable, B, nand.getInputPins().get(1)); + new GUIWire(submodelModifiable, nand.getOutputPin(), cp1, new Point[0]); + new GUIWire(submodelModifiable, cp1, not.getInputPins().get(0), new Point(45, 20)); + new GUIWire(submodelModifiable, cp1, not.getInputPins().get(1), new Point(45, 30)); new GUIWire(submodelModifiable, not.getOutputPin(), Y); } - - public Pin getPinA() - { - return pinA; - } - - public Pin getPinB() - { - return pinB; - } - - public Pin getPinY() - { - return pinY; - } - } \ No newline at end of file