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