X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=org.simantics.district.network.ui%2Fsrc%2Forg%2Fsimantics%2Fdistrict%2Fnetwork%2Fui%2FNetworkDrawingParticipant.java;h=da2bf32aec1a6ab3170e1386da2dddda8a2e9b7b;hb=refs%2Fchanges%2F55%2F3355%2F2;hp=73abf31e575bb7f03047793df0f272146ba67c01;hpb=6efcc2873091c30cbc6dbc47f5601bd62813b99f;p=simantics%2Fdistrict.git diff --git a/org.simantics.district.network.ui/src/org/simantics/district/network/ui/NetworkDrawingParticipant.java b/org.simantics.district.network.ui/src/org/simantics/district/network/ui/NetworkDrawingParticipant.java index 73abf31e..da2bf32a 100644 --- a/org.simantics.district.network.ui/src/org/simantics/district/network/ui/NetworkDrawingParticipant.java +++ b/org.simantics.district.network.ui/src/org/simantics/district/network/ui/NetworkDrawingParticipant.java @@ -3,11 +3,15 @@ package org.simantics.district.network.ui; import java.awt.geom.AffineTransform; import java.awt.geom.Point2D; +import java.awt.geom.Rectangle2D; import java.util.ArrayList; import java.util.List; +import org.simantics.district.network.ui.adapters.DistrictNetworkEdgeElement; import org.simantics.district.network.ui.adapters.DistrictNetworkVertexElement; +import org.simantics.district.network.ui.nodes.DistrictNetworkEdgeNode; import org.simantics.district.network.ui.nodes.DistrictNetworkVertexNode; +import org.simantics.district.network.ui.nodes.HoverSensitiveNode; import org.simantics.district.network.ui.nodes.NetworkDrawingNode; import org.simantics.g2d.canvas.impl.DependencyReflection.Dependency; import org.simantics.g2d.canvas.impl.SGNodeReflection.SGInit; @@ -18,12 +22,15 @@ import org.simantics.g2d.diagram.participant.AbstractDiagramParticipant; import org.simantics.g2d.element.IElement; import org.simantics.scenegraph.Node; import org.simantics.scenegraph.g2d.G2DParentNode; +import org.simantics.scenegraph.g2d.IG2DNode; import org.simantics.utils.datastructures.hints.IHintContext.Key; import org.simantics.utils.datastructures.hints.IHintContext.KeyOf; public class NetworkDrawingParticipant extends AbstractDiagramParticipant { - @Dependency + public static final String NETWORK_DRAWING_NODE = "networkDrawingNode"; + + @Dependency PickContext pick; /** @@ -48,7 +55,7 @@ public class NetworkDrawingParticipant extends AbstractDiagramParticipant { @SGInit public void initSG(G2DParentNode parent) { - node = parent.addNode("networkDrawingNode", NetworkDrawingNode.class); + node = parent.addNode(NETWORK_DRAWING_NODE, NetworkDrawingNode.class); node.setTransform(transform); node.setNetworkDrawingParticipant(this); } @@ -58,34 +65,54 @@ public class NetworkDrawingParticipant extends AbstractDiagramParticipant { node.setDiagram(newDiagram); } - public boolean pickHoveredElement(Point2D currentMousePos) { - PickRequest req = new PickRequest(currentMousePos.getX(), currentMousePos.getY()).context(getContext()); - List pickables = new ArrayList(); + public boolean pickHoveredElement(Point2D currentMousePos, boolean isConnectionTool) { + PickRequest req = new PickRequest(new Rectangle2D.Double(currentMousePos.getX(), currentMousePos.getY(), 1e-8, 1e-8)).context(getContext()); + List pickables = new ArrayList<>(); pick.pick(diagram, req, pickables); - - List snap = new ArrayList<>(diagram.getSnapshot()); - - snap.removeAll(pickables); - + + List snap = diagram.getSnapshot(); + + boolean changed = false; + changed |= hoverNodes(snap, false, isConnectionTool, currentMousePos); + changed |= hoverNodes(pickables, true, isConnectionTool, currentMousePos); + return changed; + } + + private boolean hoverNodes(List elements, boolean hover, boolean isConnectionTool, Point2D p) { boolean changed = false; - for (IElement sn : snap) { - Node node = sn.getHint(DistrictNetworkVertexElement.KEY_DN_VERTEX_NODE); + for (IElement elem : elements) { + Node node = elem.getHint(DistrictNetworkVertexElement.KEY_DN_VERTEX_NODE); if (node instanceof DistrictNetworkVertexNode) { - if (((DistrictNetworkVertexNode) node).hover(false) && !changed) { - changed = true; + changed |= ((DistrictNetworkVertexNode) node).hover(hover, isConnectionTool); + if (hover) + ((DistrictNetworkVertexNode) node).setMousePosition(p); + } else { + node = elem.getHint(DistrictNetworkEdgeElement.KEY_DN_EDGE_NODE); + if (node instanceof DistrictNetworkEdgeNode) { + for (IG2DNode n : ((DistrictNetworkEdgeNode) node).getNodes()) { + if (n instanceof HoverSensitiveNode) { + changed |= ((HoverSensitiveNode)n).hover(hover, isConnectionTool); + if (hover) + ((HoverSensitiveNode)n).setMousePosition(p); + } + } } } } - + return changed; + } + + public boolean isHoveringOverNode(Point2D currentMousePos) { + PickRequest req = new PickRequest(currentMousePos).context(getContext()); + List pickables = new ArrayList(); + pick.pick(diagram, req, pickables); for (IElement elem : pickables) { Node node = elem.getHint(DistrictNetworkVertexElement.KEY_DN_VERTEX_NODE); if (node instanceof DistrictNetworkVertexNode) { - if (((DistrictNetworkVertexNode) node).hover(true) && !changed) { - changed = true; - } + return true; } } - return changed; + return false; } public AffineTransform getTransform() {