]> gerrit.simantics Code Review - simantics/3d.git/blobdiff - org.simantics.plant3d/src/org/simantics/plant3d/scenegraph/TurnComponent.java
Allow multiple radii for turns.
[simantics/3d.git] / org.simantics.plant3d / src / org / simantics / plant3d / scenegraph / TurnComponent.java
index ff12143bcf01dd4497299aad442e42bdd1319ff7..e25fd8d4ad206fbb2faae13cf9cc8a301af27676 100644 (file)
@@ -25,6 +25,7 @@ public class TurnComponent extends PipelineComponent {
        
        private String type;
        private PipeControlPoint controlPoint;
+       private Integer turnRadiusIndex;
        
        @GetType(Plant3D.URIs.TurnComponent)
        public String getType() {
@@ -52,10 +53,9 @@ public class TurnComponent extends PipelineComponent {
        public Map<String, Object> updateParameterMap() {
                Map<String,Object> map = new HashMap<String, Object>();
                
-               PipeRun pipeRun = getPipeRun();
-               if (pipeRun != null) {
-                       map.put("turnRadius", pipeRun.getTurnRadius());
-                       map.put("radius", pipeRun.getPipeDiameter() * 0.5);
+               if (getPipeRun() != null) {
+               map.put("turnRadius", getTurnRadius());
+               map.put("radius", getDiameter() * 0.5);
                }
                if (controlPoint != null && controlPoint.getTurnAngle() != null  && !Double.isNaN(controlPoint.getTurnAngle())) {
                        map.put("turnAngle", controlPoint.getTurnAngle());
@@ -75,6 +75,7 @@ public class TurnComponent extends PipelineComponent {
                        if (calculated.containsKey("length")) {
                                controlPoint.setLength((Double)calculated.get("length"));
                        }
+                       PipingRules.requestUpdate(getControlPoint());
                }
        }
        
@@ -102,6 +103,40 @@ public class TurnComponent extends PipelineComponent {
                return getControlPoint().getTurnAxis();
        }
        
+       @GetPropertyValue(name="Turn Radius", value=Plant3D.URIs.HasTurnRadius, tabId = "Default")
+       public Double getTurnRadius() {
+           if (turnRadiusIndex != null)
+               return getPipeRun().getTurnRadiusArray()[turnRadiusIndex];
+           return getPipeRun().getTurnRadiusArray()[0];
+       }
+       
+       @RelatedGetValue(Plant3D.URIs.HasTurnRadiusIndex)
+       @GetPropertyValue(name="Turn Radius Index", value=Plant3D.URIs.HasTurnRadiusIndex, tabId = "Default")
+       public Integer getTurnRadiusIndex() 
+       {
+        // TODO: For backwards compatibility, we do not accept null values. 
+        //       One development path would allow null index, and setting custom turn radius for the component.
+        if (turnRadiusIndex == null)
+               return 0;
+           return turnRadiusIndex;
+       }
+       
+       @RelatedSetValue(Plant3D.URIs.HasTurnRadiusIndex)
+       @SetPropertyValue(value=Plant3D.URIs.HasTurnRadiusIndex)
+    public void setTurnRadiusIndex(Integer turnRadiusIndex) {
+           if (this.turnRadiusIndex == turnRadiusIndex)
+               return;
+           if (turnRadiusIndex == null)
+               return;
+           if (turnRadiusIndex != null) {
+               if (getPipeRun().getTurnRadiusArray().length <= turnRadiusIndex)
+                   return;
+           }
+           this.turnRadiusIndex = turnRadiusIndex;
+        firePropertyChanged(Plant3D.URIs.HasTurnRadiusIndex);
+        PipingRules.requestUpdate(getControlPoint());
+    }
+       
        @RelatedGetValue(Plant3D.URIs.HasRotationAngle)
        @GetPropertyValue(name="Rotation Angle", value=Plant3D.URIs.HasRotationAngle, tabId = "Default")
        public Double getRotationAngle() {
@@ -125,12 +160,7 @@ public class TurnComponent extends PipelineComponent {
                if (controlPoint.getRotationAngle() != null && Math.abs(controlPoint.getRotationAngle()-angle) < MathTools.NEAR_ZERO)
                        return;
                controlPoint.setRotationAngle(angle);
-               try {
-                       PipingRules.requestUpdate(getControlPoint());
-               } catch (Exception e) {
-                       // TODO Auto-generated catch block
-                       e.printStackTrace();
-               }   
+               PipingRules.requestUpdate(getControlPoint());
        }
        
        @RelatedGetValue(Plant3D.URIs.IsReversed)
@@ -142,7 +172,6 @@ public class TurnComponent extends PipelineComponent {
                return d;
        }
        @RelatedSetValue(Plant3D.URIs.IsReversed)
-       //@SetPropertyValue(value=Plant3D.URIs.IsReversed)
        public void setReversed(Boolean reverse) {
                if (!controlPoint.isFixed())
                        return;
@@ -151,12 +180,7 @@ public class TurnComponent extends PipelineComponent {
                        return;
                }
                controlPoint.setReversed(reverse);
-               try {
-                       PipingRules.requestUpdate(getControlPoint());
-               } catch (Exception e) {
-                       // TODO Auto-generated catch block
-                       e.printStackTrace();
-               }   
+               PipingRules.requestUpdate(getControlPoint()); 
        }
        
        @Override