projects
/
Mograsim.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Added a GUIComponent resize listener
[Mograsim.git]
/
net.mograsim.logic.ui
/
src
/
net
/
mograsim
/
logic
/
ui
/
LogicUIRenderer.java
diff --git
a/net.mograsim.logic.ui/src/net/mograsim/logic/ui/LogicUIRenderer.java
b/net.mograsim.logic.ui/src/net/mograsim/logic/ui/LogicUIRenderer.java
index
5182a24
..
7858a70
100644
(file)
--- a/
net.mograsim.logic.ui/src/net/mograsim/logic/ui/LogicUIRenderer.java
+++ b/
net.mograsim.logic.ui/src/net/mograsim/logic/ui/LogicUIRenderer.java
@@
-22,8
+22,16
@@
public class LogicUIRenderer
public void render(GeneralGC gc, Rectangle visibleRegion)
{
public void render(GeneralGC gc, Rectangle visibleRegion)
{
+ gc.setAntialias(SWT.ON);
+ gc.setClipping(visibleRegion);
gc.setLineWidth(.5);
gc.setLineWidth(.5);
- model.getWires().forEach(w -> w.render(gc));
+ model.getWires().forEach(w ->
+ {
+ Rectangle bounds = w.getBounds();
+ double lw = gc.getLineWidth();
+ if (visibleRegion.intersects(bounds.x - lw, bounds.y - lw, bounds.width + lw + lw, bounds.height + lw + lw))
+ w.render(gc);
+ });
model.getComponents().forEach(c -> renderComponent(gc, c, visibleRegion));
}
model.getComponents().forEach(c -> renderComponent(gc, c, visibleRegion));
}
@@
-37,7
+45,7
@@
public class LogicUIRenderer
if (DRAW_PINS)
{
gc.setBackground(gc.getDevice().getSystemColor(SWT.COLOR_DARK_CYAN));
if (DRAW_PINS)
{
gc.setBackground(gc.getDevice().getSystemColor(SWT.COLOR_DARK_CYAN));
- for (Pin p : component.getPins())
+ for (Pin p : component.getPins()
.values()
)
{
Point pos = p.getPos();
gc.fillOval(pos.x - 1, pos.y - 1, 2, 2);
{
Point pos = p.getPos();
gc.fillOval(pos.x - 1, pos.y - 1, 2, 2);