import net.mograsim.logic.model.model.ViewModelModifiable;
import net.mograsim.logic.model.model.components.GUIComponent;
import net.mograsim.logic.model.model.wires.Pin;
+import net.mograsim.logic.model.model.wires.PinUsage;
import net.mograsim.logic.model.modeladapter.ViewLogicModelAdapter;
import net.mograsim.logic.model.modeladapter.componentadapters.SplitterAdapter;
import net.mograsim.logic.model.serializing.IdentifierGetter;
{
super(model, name);
this.logicWidth = logicWidth;
- setSize(width, logicWidth * heightPerPin);
- addPin(this.inputPin = new Pin(this, "I", logicWidth, 0, (logicWidth - 1) * heightPerPin / 2));
- double outputHeight = 0;
- for (int i = 0; i < logicWidth; i++, outputHeight += 10)
- addPin(new Pin(this, "O" + i, 1, width, outputHeight));
+ setSize(width, (logicWidth - 1) * heightPerPin);
+ addPin(this.inputPin = new Pin(this, "I", logicWidth, PinUsage.TRISTATE, 0, (logicWidth - 1) * heightPerPin / 2));
+ double outputHeight = (logicWidth - 1) * heightPerPin;
+ for (int i = 0; i < logicWidth; i++, outputHeight -= 10)
+ addPin(new Pin(this, "O" + i, 1, PinUsage.TRISTATE, width, outputHeight));
outputEnds = new ReadEnd[logicWidth];
}
gc.setForeground(ColorManager.current().toColor(c));
double inLineY = posY + (logicWidth - 1) * heightPerPin / 2;
gc.drawLine(posX, inLineY, posX + width / 2, inLineY);
- double outputHeight = posY;
- for (int i = 0; i < logicWidth; i++, outputHeight += 10)
+ double outputHeight = posY + (logicWidth - 1) * heightPerPin;
+ for (int i = 0; i < logicWidth; i++, outputHeight -= 10)
{
c = BitVectorFormatter.formatAsColor(outputEnds[i]);
if (c != null)