double posX = getPosX();
double posY = getPosY();
+ ColorDefinition c = BitVectorFormatter.formatAsColor(outputEnd);
+ if (c != null)
+ gc.setForeground(ColorManager.current().toColor(c));
+ double outLineY = posY + (logicWidth - 1) * heightPerPin / 2;
+ gc.drawLine(posX + width / 2, outLineY, posX + width, outLineY);
double inputHeight = posY;
for (int i = 0; i < logicWidth; i++, inputHeight += 10)
{
- ColorDefinition c = BitVectorFormatter.formatAsColor(inputEnds[i]);
+ c = BitVectorFormatter.formatAsColor(inputEnds[i]);
if (c != null)
gc.setForeground(ColorManager.current().toColor(c));
gc.drawLine(posX, inputHeight, posX + width / 2, inputHeight);
gc.setLineCap(lineJoin == SWT.JOIN_MITER ? SWT.CAP_SQUARE : lineJoin == SWT.JOIN_ROUND ? SWT.CAP_ROUND : SWT.CAP_SQUARE);
gc.drawLine(posX + width / 2, posY, posX + width / 2, posY + heightPerPin * (logicWidth - 1));
gc.setLineCap(oldLineCap);
- ColorDefinition c = BitVectorFormatter.formatAsColor(outputEnd);
- if (c != null)
- gc.setForeground(ColorManager.current().toColor(c));
- double outLineY = posY + (logicWidth - 1) * heightPerPin / 2;
- gc.drawLine(posX + width / 2, outLineY, posX + width, outLineY);
}
@Override
gc.setForeground(ColorManager.current().toColor(c));
double inLineY = posY + (logicWidth - 1) * heightPerPin / 2;
gc.drawLine(posX, inLineY, posX + width / 2, inLineY);
- gc.setForeground(Preferences.current().getColor("net.mograsim.logic.model.color.foreground"));
- int oldLineCap = gc.getLineCap();
- int lineJoin = gc.getLineJoin();
- // TODO find better "replacement" for JOIN_BEVEL
- gc.setLineCap(lineJoin == SWT.JOIN_MITER ? SWT.CAP_SQUARE : lineJoin == SWT.JOIN_ROUND ? SWT.CAP_ROUND : SWT.CAP_SQUARE);
- gc.drawLine(posX + width / 2, posY, posX + width / 2, posY + heightPerPin * (logicWidth - 1));
- gc.setLineCap(oldLineCap);
double outputHeight = posY;
for (int i = 0; i < logicWidth; i++, outputHeight += 10)
{
gc.setForeground(ColorManager.current().toColor(c));
gc.drawLine(posX + width / 2, outputHeight, posX + width, outputHeight);
}
+ gc.setForeground(Preferences.current().getColor("net.mograsim.logic.model.color.foreground"));
+ int oldLineCap = gc.getLineCap();
+ int lineJoin = gc.getLineJoin();
+ // TODO find better "replacement" for JOIN_BEVEL
+ gc.setLineCap(lineJoin == SWT.JOIN_MITER ? SWT.CAP_SQUARE : lineJoin == SWT.JOIN_ROUND ? SWT.CAP_ROUND : SWT.CAP_SQUARE);
+ gc.drawLine(posX + width / 2, posY, posX + width / 2, posY + heightPerPin * (logicWidth - 1));
+ gc.setLineCap(oldLineCap);
}
@Override
for (int i = 0; i < guiComponent.logicWidth; i++)
{
Wire input = logicWiresPerPin.get(guiComponent.getPin("I" + i));
- Wire.fuse(input, output, 0, i, 1);
+ Wire.fuse(input, output, 0, guiComponent.logicWidth - 1 - i, 1);
inputEnds[i] = input.createReadOnlyEnd();
}
guiComponent.setLogicModelBinding(inputEnds, output.createReadOnlyEnd());
for (int i = 0; i < guiComponent.logicWidth; i++)
{
Wire output = logicWiresPerPin.get(guiComponent.getPin("O" + i));
- Wire.fuse(input, output, i, 0, 1);
+ Wire.fuse(input, output, guiComponent.logicWidth - 1 - i, 0, 1);
outputEnds[i] = output.createReadOnlyEnd();
}
guiComponent.setLogicModelBinding(input.createReadOnlyEnd(), outputEnds);