]> gerrit.simantics Code Review - simantics/district.git/blobdiff - org.simantics.district.network.ui/src/org/simantics/district/network/ui/adapters/DistrictNetworkEdgeElementFactory.java
Some cleaning and fixing of district functionalities
[simantics/district.git] / org.simantics.district.network.ui / src / org / simantics / district / network / ui / adapters / DistrictNetworkEdgeElementFactory.java
index c3058a0edf5518341c6389ca61ad188019a0b85c..36d573081b8489bec41274311008eed35f33c624 100644 (file)
@@ -1,6 +1,5 @@
 package org.simantics.district.network.ui.adapters;
 
-import java.awt.geom.Path2D;
 import java.awt.geom.Point2D;
 
 import org.simantics.db.AsyncReadGraph;
@@ -14,7 +13,6 @@ import org.simantics.diagram.synchronization.IModifiableSynchronizationContext;
 import org.simantics.diagram.synchronization.SynchronizationHints;
 import org.simantics.diagram.synchronization.graph.GraphSynchronizationHints;
 import org.simantics.diagram.synchronization.graph.layer.GraphLayerManager;
-import org.simantics.district.network.ModelledCRS;
 import org.simantics.district.network.ontology.DistrictNetworkResource;
 import org.simantics.district.network.ui.DistrictNetworkEdge;
 import org.simantics.g2d.canvas.ICanvasContext;
@@ -55,30 +53,19 @@ public class DistrictNetworkEdgeElementFactory extends SyncElementFactory {
         Resource startVertex = graph.getSingleObject(edgeResource, DN.HasStartVertex);
         Resource endVertex = graph.getSingleObject(edgeResource, DN.HasEndVertex);
 
-        // TODO: fix scale..
-        double scale = 100000;
-        
+        // TODO: Find maybe a better way to apply the scaling 
         double[] startCoords = graph.getRelatedValue2(startVertex, DIA.HasLocation);
-        
-        double startLon = ModelledCRS.longitudeToX(startCoords[0]) * scale;
-        double startLat = ModelledCRS.latitudeToY(startCoords[1]) * scale;
-        
         double[] endCoords = graph.getRelatedValue2(endVertex, DIA.HasLocation);
-
-        double endLon = ModelledCRS.longitudeToX(endCoords[0]) * scale;
-        double endLat = ModelledCRS.latitudeToY(endCoords[1]) * scale;
-        
-        Path2D path = new Path2D.Double();
-        path.moveTo(startLon, startLat);
-        path.lineTo(endLon, endLat);
-        
-        DistrictNetworkEdge edge = new DistrictNetworkEdge(path);
+        DistrictNetworkEdge edge = new DistrictNetworkEdge(new Point2D.Double(startCoords[0], startCoords[1]), new Point2D.Double(endCoords[0], endCoords[1]));
 
         Resource mapping = graph.getSingleObject(edgeResource, DistrictNetworkResource.getInstance(graph).HasMapping);
         element.setHint(DistrictNetworkAdditionalColor.KEY_DN_MAPPING_RESOURCE, mapping);
         
         element.setHint(DistrictNetworkEdgeElement.KEY_DN_EDGE, edge);
         
+        // set scaling transform
+        ElementUtils.setTransform(element, MapScalingTransform.INSTANCE);
+        
         IModifiableSynchronizationContext context = diagram.getHint(SynchronizationHints.CONTEXT);
         GraphLayerManager layerManager = context.get(GraphSynchronizationHints.GRAPH_LAYER_MANAGER);