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;
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();
}
}
});