- @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();
- }
+ public Double getTurnRadius() {
+ if (turnRadiusIndex != null)
+ return getPipeRun().getTurnRadiusArray()[turnRadiusIndex];
+ return getPipeRun().getTurnRadiusArray()[0];
+ }
+
+ @RelatedGetValue(Plant3D.URIs.HasTurnRadiusIndex)
+ @GetComboPropertyValue(name="Turn Radius", 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)
+ @SetComboPropertyValue(value=Plant3D.URIs.HasTurnRadiusIndex)
+ public void setTurnRadiusIndex(Integer turnRadiusIndex) {
+ if (this.turnRadiusIndex == turnRadiusIndex)
+ return;
+ if (turnRadiusIndex == null || turnRadiusIndex < 0)
+ return;
+ if (turnRadiusIndex != null && getPipeRun() != null) {
+ if (getPipeRun().getTurnRadiusArray().length <= turnRadiusIndex)
+ return;
+ }
+ this.turnRadiusIndex = turnRadiusIndex;
+ firePropertyChanged(Plant3D.URIs.HasTurnRadiusIndex);
+ PipingRules.requestUpdate(getControlPoint());