]> gerrit.simantics Code Review - simantics/district.git/blobdiff - org.simantics.district.network.ui/src/org/simantics/district/network/ui/participants/DNTranslateMode.java
Final push of district changes
[simantics/district.git] / org.simantics.district.network.ui / src / org / simantics / district / network / ui / participants / DNTranslateMode.java
index 27de17e921f0ce9bb765a9f022075eee8504f9d3..12caba477724d4af843abc1e43413ab1536d0698 100644 (file)
@@ -14,6 +14,7 @@ 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.ModelledCRS;
 import org.simantics.district.network.ontology.DistrictNetworkResource;
 import org.simantics.g2d.canvas.Hints;
 import org.simantics.g2d.diagram.participant.pointertool.TranslateMode;
@@ -49,8 +50,16 @@ public class DNTranslateMode extends TranslateMode {
                             Resource res = (Resource) obj;
                             AffineTransform at = ElementUtils.getLocalTransform(e, new AffineTransform());
                             if (graph.isInstanceOf(res, DN.Vertex)) {
+                                
+                                double x = at.getTranslateX();
+                                double y = at.getTranslateY();
+                                // TODO: Fix scale!
+                                double scale = 100000;
+                                double lat = ModelledCRS.yToLatitude(y / scale);
+                                double lon = ModelledCRS.xToLongitude(x / scale);
+                                
                                 // write to db
-                                double[] coords = new double[] { at.getTranslateX(), at.getTranslateY() };
+                                double[] coords = new double[] { lon, lat };
                                 graph.claimLiteral(res, DIA.HasLocation, coords);
                             } else {
                                 // fallback to normal HasTransforms