X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=org.simantics.plant3d%2Fsrc%2Forg%2Fsimantics%2Fplant3d%2Fscenegraph%2FTurnComponent.java;h=a1374def587c857a3b0327cba4510891896838be;hb=a1e1faa6915445e786f482170576b9c9d0f5d982;hp=9a124349e7f7b950af3cf9b1423285a188fb1332;hpb=0a0e6285c47fea669cf580c57682cc8f473db411;p=simantics%2F3d.git diff --git a/org.simantics.plant3d/src/org/simantics/plant3d/scenegraph/TurnComponent.java b/org.simantics.plant3d/src/org/simantics/plant3d/scenegraph/TurnComponent.java index 9a124349..a1374def 100644 --- a/org.simantics.plant3d/src/org/simantics/plant3d/scenegraph/TurnComponent.java +++ b/org.simantics.plant3d/src/org/simantics/plant3d/scenegraph/TurnComponent.java @@ -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 updateParameterMap() { Map map = new HashMap(); - 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()); @@ -70,7 +70,7 @@ public class TurnComponent extends PipelineComponent { @Override public void updateParameters() { super.updateParameters(); - if (!isVariableAngle()) { + if (controlPoint.asFixedAngle()) { Map calculated = getCalculatedParameters(); if (calculated.containsKey("length")) { controlPoint.setLength((Double)calculated.get("length")); @@ -81,12 +81,14 @@ public class TurnComponent extends PipelineComponent { @RelatedGetValue(Plant3D.URIs.HasTurnAngle) public Double getTurnAngle() { + if (!getControlPoint().asFixedAngle()) + return null; return getControlPoint().getTurnAngle(); } @RelatedSetValue(Plant3D.URIs.HasTurnAngle) public void setTurnAngle(Double a) { - if (!getControlPoint().isFixed()) + if (!getControlPoint().asFixedAngle()) return; getControlPoint().setTurnAngle(a); } @@ -103,10 +105,44 @@ public class TurnComponent extends PipelineComponent { return getControlPoint().getTurnAxis(); } + @GetPropertyValue(name="Turn Radius", value="TurnRadius", 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 && getPipeRun() != 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() { - if (!controlPoint.isFixed()) + if (!controlPoint.asFixedAngle()) return null; Double d = controlPoint.getRotationAngle(); if (d == null) @@ -116,7 +152,7 @@ public class TurnComponent extends PipelineComponent { @RelatedSetValue(Plant3D.URIs.HasRotationAngle) @SetPropertyValue(value=Plant3D.URIs.HasRotationAngle) public void setRotationAngle(Double angle) { - if (!controlPoint.isFixed()) + if (!controlPoint.asFixedAngle()) return; if (angle == null || Double.isInfinite(angle) || Double.isNaN(angle)) { @@ -126,38 +162,27 @@ 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) @GetPropertyValue(name="Reverse", value=Plant3D.URIs.IsReversed, tabId = "Default") public Boolean isReversed() { - if (!controlPoint.isFixed()) + if (!controlPoint.asFixedAngle()) 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()) + if (!controlPoint.asFixedAngle()) return; if (reverse == null) { return; } controlPoint.setReversed(reverse); - try { - PipingRules.requestUpdate(getControlPoint()); - } catch (Exception e) { - // TODO Auto-generated catch block - e.printStackTrace(); - } + PipingRules.requestUpdate(getControlPoint()); } @Override