package era.mi.gui;\r
\r
-import java.util.HashMap;\r
import java.util.HashSet;\r
-import java.util.Map;\r
import java.util.Set;\r
\r
import org.eclipse.swt.SWT;\r
import org.eclipse.swt.widgets.Composite;\r
import org.eclipse.swt.widgets.Event;\r
\r
-import era.mi.gui.components.BasicGUIComponent;\r
-import era.mi.gui.wires.GUIWire;\r
+import era.mi.gui.model.components.GUIComponent;\r
+import era.mi.gui.model.wires.GUIWire;\r
+import era.mi.gui.model.wires.Pin;\r
import net.haspamelodica.swt.helper.gcs.GeneralGC;\r
-import net.haspamelodica.swt.helper.gcs.TranslatedGC;\r
import net.haspamelodica.swt.helper.swtobjectwrappers.Point;\r
+import net.haspamelodica.swt.helper.swtobjectwrappers.Rectangle;\r
import net.haspamelodica.swt.helper.zoomablecanvas.ZoomableCanvas;\r
\r
/**\r
*/\r
public class LogicUICanvas extends ZoomableCanvas\r
{\r
- private final Set<BasicGUIComponent> components;\r
- private final Map<BasicGUIComponent, Point> componentPositions;\r
+ private final Set<GUIComponent> components;\r
private final Set<GUIWire> wires;\r
\r
public LogicUICanvas(Composite parent, int style)\r
super(parent, style);\r
\r
components = new HashSet<>();\r
- componentPositions = new HashMap<>();\r
wires = new HashSet<>();\r
\r
- addZoomedRenderer(gc -> components.forEach(c -> drawComponent(gc, c)));\r
+ addZoomedRenderer(gc ->\r
+ {\r
+ Rectangle visibleRegion = new Rectangle(offX, offY, gW / zoom, gH / zoom);\r
+ components.forEach(c -> drawComponent(gc, c, visibleRegion));\r
+ });\r
addZoomedRenderer(gc -> wires.forEach(w -> w.render(gc)));\r
addListener(SWT.MouseDown, this::mouseDown);\r
}\r
* \r
* @author Daniel Kirschten\r
*/\r
- public <C extends BasicGUIComponent> C addComponent(C component, double x, double y)\r
+ // TODO replace with model change listener\r
+ public <C extends GUIComponent> C addComponent(C component)\r
{\r
components.add(component);\r
- componentPositions.put(component, new Point(x, y));\r
return component;\r
}\r
\r
* \r
* @author Daniel Kirschten\r
*/\r
- public void addWire(BasicGUIComponent component1, int component1ConnectionIndex, BasicGUIComponent component2,\r
- int component2ConnectionIndex, Point... path)\r
+ // TODO replace with model change listener\r
+ public void addWire(Pin pin1, Pin pin2, Point... path)\r
{\r
- wires.add(new GUIWire(this::redrawThreadsafe, component1, component1ConnectionIndex, componentPositions.get(component1), component2,\r
- component2ConnectionIndex, componentPositions.get(component2), path));\r
+ wires.add(new GUIWire(this::redrawThreadsafe, pin1, pin2, path));\r
}\r
\r
- private void drawComponent(GeneralGC gc, BasicGUIComponent component)\r
+ private void drawComponent(GeneralGC gc, GUIComponent component, Rectangle visibleRegion)\r
{\r
- TranslatedGC tgc = new TranslatedGC(gc, componentPositions.get(component));\r
- component.render(tgc);\r
- tgc.setBackground(getDisplay().getSystemColor(SWT.COLOR_BLUE));\r
+ component.render(gc, visibleRegion);\r
+ gc.setBackground(getDisplay().getSystemColor(SWT.COLOR_CYAN));\r
+ for (Pin p : component.getPins())\r
+ {\r
+ Point pos = p.getPos();\r
+ gc.fillOval(pos.x - 1, pos.y - 1, 2, 2);\r
+ }\r
}\r
\r
private void mouseDown(Event e)\r
if (e.button == 1)\r
{\r
Point click = displayToWorldCoords(e.x, e.y);\r
- for (BasicGUIComponent component : components)\r
- if (component.getBounds().translate(componentPositions.get(component)).contains(click))\r
+ for (GUIComponent component : components)\r
+ if (component.getBounds().contains(click))\r
{\r
if (component.clicked(click.x, click.y))\r
redraw();\r