]> gerrit.simantics Code Review - simantics/district.git/blobdiff - org.simantics.district.network.ui/src/org/simantics/district/network/ui/nodes/DistrictNetworkEdgeNode.java
Stash for edge styling & import progress monitoring
[simantics/district.git] / org.simantics.district.network.ui / src / org / simantics / district / network / ui / nodes / DistrictNetworkEdgeNode.java
index 745f2a80fccb04dbf0e83bbc2bfeff5b252489b0..030802755080b61135ddae9951c3293c663bcde4 100644 (file)
@@ -31,6 +31,8 @@ public class DistrictNetworkEdgeNode extends G2DNode {
 
     private Color color;
 
+    private Double stroke;
+
     @Override
     public void init() {
     }
@@ -61,7 +63,12 @@ public class DistrictNetworkEdgeNode extends G2DNode {
         g2d.setColor(color);
         if (STROKE != null) {
             if (scaleStroke && STROKE instanceof BasicStroke) {
-                BasicStroke bs = GeometryUtils.scaleStroke(STROKE, (float) (1.0 / GeometryUtils.getScale(g2d.getTransform())));
+                double str;
+                if (stroke != null)
+                    str = stroke;
+                else
+                    str = 1.0;
+                BasicStroke bs = GeometryUtils.scaleStroke(STROKE, (float) (str / GeometryUtils.getScale(g2d.getTransform())));
                 g2d.setStroke(bs);
             } else {
                 g2d.setStroke(STROKE);
@@ -82,9 +89,9 @@ public class DistrictNetworkEdgeNode extends G2DNode {
     public static Path2D calculatePath(DistrictNetworkEdge edge) {
         // Convert to screen coordinates
         double startX = ModelledCRS.longitudeToX(edge.getStartPoint().getX());
-        double startY = ModelledCRS.latitudeToY(edge.getStartPoint().getY());
+        double startY = ModelledCRS.latitudeToY(-edge.getStartPoint().getY()); // Invert for Simantics
         double endX = ModelledCRS.longitudeToX(edge.getEndPoint().getX());
-        double endY = ModelledCRS.latitudeToY(edge.getEndPoint().getY());
+        double endY = ModelledCRS.latitudeToY(-edge.getEndPoint().getY());// Invert for Simantics
         
         // render
         Path2D path = new Path2D.Double();
@@ -126,4 +133,9 @@ public class DistrictNetworkEdgeNode extends G2DNode {
         return color;
     }
 
+    @PropertySetter(value = "stroke")
+    public void setStroke(Double stroke) {
+        this.stroke = stroke / 100;
+    }
+
 }