]> gerrit.simantics Code Review - simantics/3d.git/blobdiff - org.simantics.plant3d/src/org/simantics/plant3d/scenegraph/TurnComponent.java
Preliminary example of creating pipes with elbow coordinates
[simantics/3d.git] / org.simantics.plant3d / src / org / simantics / plant3d / scenegraph / TurnComponent.java
index 5f8139f42d919bfb40f3a22131f7302a1a25f85d..0205f5a318f9778531a36160414ad99ab5d4f497 100644 (file)
@@ -7,13 +7,17 @@ import javax.vecmath.Vector3d;
 
 import org.simantics.g3d.math.MathTools;
 import org.simantics.g3d.property.annotations.GetPropertyValue;
+import org.simantics.g3d.property.annotations.SetPropertyValue;
 import org.simantics.g3d.scenegraph.base.ParentNode;
 import org.simantics.objmap.graph.annotations.DynamicGraphType;
 import org.simantics.objmap.graph.annotations.GetType;
+import org.simantics.objmap.graph.annotations.RelatedGetValue;
+import org.simantics.objmap.graph.annotations.RelatedSetValue;
 import org.simantics.objmap.graph.annotations.SetType;
 import org.simantics.plant3d.ontology.Plant3D;
 import org.simantics.plant3d.scenegraph.controlpoint.ControlPointFactory;
 import org.simantics.plant3d.scenegraph.controlpoint.PipeControlPoint;
+import org.simantics.plant3d.scenegraph.controlpoint.PipingRules;
 
 @DynamicGraphType(Plant3D.URIs.TurnComponent)
 public class TurnComponent extends PipelineComponent {
@@ -59,11 +63,33 @@ public class TurnComponent extends PipelineComponent {
                return map;
        }
        
+       public boolean isVariableAngle() {
+        return !controlPoint.isFixed();
+    }
        
+       @Override
+       public void updateParameters() {
+           super.updateParameters();
+           if (!isVariableAngle()) {
+            Map<String,Object> calculated = getCalculatedParameters();
+            if (calculated.containsKey("length")) {
+                controlPoint.setLength((Double)calculated.get("length"));
+            }
+        }
+       }
+       
+       @RelatedGetValue(Plant3D.URIs.HasTurnAngle)
        public Double getTurnAngle() {
                return getControlPoint().getTurnAngle();
        }
        
+       @RelatedSetValue(Plant3D.URIs.HasTurnAngle)
+       public void setTurnAngle(Double a) {
+           if (!getControlPoint().isFixed())
+               return;
+           getControlPoint().setTurnAngle(a);            
+       }
+       
        @GetPropertyValue(name="Turn Angle", value="turn angle", tabId = "Default")
        public Double getTurnAngleDeg() {
                Double d = getControlPoint().getTurnAngle();
@@ -76,10 +102,62 @@ public class TurnComponent extends PipelineComponent {
                return getControlPoint().getTurnAxis();
        }
        
-       @Override
-       public Vector3d getNormal() {
-               return getTurnAxis();
-       }
+       @RelatedGetValue(Plant3D.URIs.HasRotationAngle)
+    @GetPropertyValue(name="Rotation Angle", value=Plant3D.URIs.HasRotationAngle, tabId = "Default")
+    public Double getRotationAngle() {
+        if (!controlPoint.isFixed())
+            return null;
+        Double d = controlPoint.getRotationAngle();
+        if (d == null)
+            return 0.0;
+        return MathTools.radToDeg(d);
+    }
+    @RelatedSetValue(Plant3D.URIs.HasRotationAngle)
+    @SetPropertyValue(value=Plant3D.URIs.HasRotationAngle)
+    public void setRotationAngle(Double angle) {
+        if (!controlPoint.isFixed())
+            return;
+        
+        if (angle == null || Double.isInfinite(angle) || Double.isNaN(angle)) {
+            return;
+        }
+        angle = MathTools.degToRad(angle);
+        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();
+        }   
+    }
+    
+    @RelatedGetValue(Plant3D.URIs.IsReversed)
+    @GetPropertyValue(name="Reverse", value=Plant3D.URIs.IsReversed, tabId = "Default")
+    public Boolean isReversed() {
+        if (!controlPoint.isFixed())
+            return null;
+        Boolean d = controlPoint._getReversed();
+        return d;
+    }
+    @RelatedSetValue(Plant3D.URIs.IsReversed)
+    //@SetPropertyValue(value=Plant3D.URIs.IsReversed)
+    public void setReversed(Boolean reverse) {
+        if (!controlPoint.isFixed())
+            return;
+        
+        if (reverse == null) {
+            return;
+        }
+        controlPoint.setReversed(reverse);
+        try {
+            PipingRules.requestUpdate(getControlPoint());
+        } catch (Exception e) {
+            // TODO Auto-generated catch block
+            e.printStackTrace();
+        }   
+    }
        
        @Override
        protected double[] getColor() {