X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=org.simantics.district.network.ui%2Fsrc%2Forg%2Fsimantics%2Fdistrict%2Fnetwork%2Fui%2Fparticipants%2FDNPointerInteractor.java;h=a1a8ae5ac5169ff2216549c3b537137f29ab17f7;hb=16ee01dc5a40981c58fd5b478b89552e5814e8bb;hp=acb0acacba55246f739a174c9d3d850de4835201;hpb=9dace20146d19dd0541480a80fd289de45b6cfc8;p=simantics%2Fdistrict.git diff --git a/org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNPointerInteractor.java b/org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNPointerInteractor.java index acb0acac..a1a8ae5a 100644 --- a/org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNPointerInteractor.java +++ b/org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNPointerInteractor.java @@ -11,8 +11,10 @@ import org.simantics.g2d.canvas.ICanvasParticipant; import org.simantics.g2d.diagram.handler.PickRequest.PickSorter; import org.simantics.g2d.diagram.participant.pointertool.PointerInteractor; import org.simantics.g2d.diagram.participant.pointertool.TerminalUtil.TerminalInfo; +import org.simantics.g2d.element.ElementHints; import org.simantics.g2d.element.IElement; -import org.simantics.scenegraph.g2d.G2DNode; +import org.simantics.scenegraph.g2d.IG2DNode; +import org.simantics.scenegraph.g2d.nodes.SingleElementNode; public class DNPointerInteractor extends PointerInteractor { @@ -21,8 +23,8 @@ public class DNPointerInteractor extends PointerInteractor { @Override public void sort(List elements) { Collections.sort(elements, (e1, e2) -> { - G2DNode e1node = getNode(e1); - G2DNode e2node = getNode(e2); + IG2DNode e1node = getNode(e1); + IG2DNode e2node = getNode(e2); if (e1node.getZIndex() < e2node.getZIndex()) return -1; else if (e1node.getZIndex() > e2node.getZIndex()) @@ -31,10 +33,17 @@ public class DNPointerInteractor extends PointerInteractor { }); } - private static G2DNode getNode(IElement element) { - G2DNode node = element.getHint(DistrictNetworkEdgeElement.KEY_DN_EDGE_NODE); + private static IG2DNode getNode(IElement element) { + IG2DNode node = element.getHint(DistrictNetworkEdgeElement.KEY_DN_EDGE_NODE); if (node == null) node = element.getHint(DistrictNetworkVertexElement.KEY_DN_VERTEX_NODE); + if (node == null) { + node = element.getHint(ElementHints.KEY_SG_NODE); + if (node instanceof SingleElementNode) { + SingleElementNode snode = (SingleElementNode) node; + node = snode.getNodes().iterator().next(); + } + } return node; } }