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%2FDNTranslateMode.java;h=27de17e921f0ce9bb765a9f022075eee8504f9d3;hb=16ee01dc5a40981c58fd5b478b89552e5814e8bb;hp=7d8af3d67f1103c4bca0db0765f374f19bca101f;hpb=9dace20146d19dd0541480a80fd289de45b6cfc8;p=simantics%2Fdistrict.git diff --git a/org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNTranslateMode.java b/org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNTranslateMode.java index 7d8af3d6..27de17e9 100644 --- a/org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNTranslateMode.java +++ b/org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNTranslateMode.java @@ -11,6 +11,7 @@ import org.simantics.db.WriteGraph; import org.simantics.db.common.CommentMetadata; import org.simantics.db.common.request.WriteRequest; import org.simantics.db.exception.DatabaseException; +import org.simantics.diagram.elements.ElementTransforms; import org.simantics.diagram.elements.ElementTransforms.TransformedObject; import org.simantics.diagram.stubs.DiagramResource; import org.simantics.district.network.ontology.DistrictNetworkResource; @@ -46,24 +47,26 @@ public class DNTranslateMode extends TranslateMode { Object obj = ElementUtils.getObject(e); if (obj instanceof Resource) { Resource res = (Resource) obj; + AffineTransform at = ElementUtils.getLocalTransform(e, new AffineTransform()); if (graph.isInstanceOf(res, DN.Vertex)) { - AffineTransform at = ElementUtils.getLocalTransform(e, new AffineTransform()); - transformed.add( new TransformedObject((Resource) obj, at) ); - - // write to db double[] coords = new double[] { at.getTranslateX(), at.getTranslateY() }; graph.claimLiteral(res, DIA.HasLocation, coords); + } else { + // fallback to normal HasTransforms + transformed.add( new TransformedObject((Resource) obj, at) ); } } } - if (!transformed.isEmpty()) { + graph.markUndoPoint(); + // Normal transforms + ElementTransforms.setTransformRequest(transformed).perform(graph); + CommentMetadata cm = graph.getMetadata(CommentMetadata.class); graph.addMetadata(cm.add("Translated " + transformed.size() + " " + (transformed.size() == 1 ? "element" : "elements") + " by (" + dx + "," + dy + ") mm.")); - graph.markUndoPoint(); } } });