--- /dev/null
+package org.simantics.g3d.csg.scenegraph2;\r
+\r
+import org.jcae.opencascade.jni.TopoDS_Shape;\r
+import org.simantics.g3d.csg.ontology.CSG;\r
+import org.simantics.g3d.property.annotations.GetPropertyValue;\r
+import org.simantics.g3d.property.annotations.SetPropertyValue;\r
+import org.simantics.objmap.graph.annotations.GraphType;\r
+import org.simantics.objmap.graph.annotations.RelatedGetValue;\r
+import org.simantics.objmap.graph.annotations.RelatedSetValue;\r
+import org.simantics.opencascade.OccTriangulator;\r
+\r
+@GraphType(CSG.URIs.Box)\r
+public class BoxNode extends CSGnode {\r
+\r
+ private double sx = 1.0;\r
+ private double sy = 1.0;\r
+ private double sz = 1.0;\r
+ \r
+ public BoxNode() {\r
+ System.out.println();\r
+ }\r
+ \r
+ @RelatedSetValue(CSG.URIs.HasXAxisSize)\r
+ @SetPropertyValue(CSG.URIs.HasXAxisSize)\r
+ public void setSX(double d) {\r
+ this.sx = d;\r
+ firePropertyChanged(CSG.URIs.HasXAxisSize);\r
+ }\r
+ \r
+ @RelatedSetValue(CSG.URIs.HasYAxisSize)\r
+ @SetPropertyValue(CSG.URIs.HasYAxisSize)\r
+ public void setSY(double d) {\r
+ this.sy = d;\r
+ firePropertyChanged(CSG.URIs.HasYAxisSize);\r
+ }\r
+ \r
+ @RelatedSetValue(CSG.URIs.HasZAxisSize)\r
+ @SetPropertyValue(CSG.URIs.HasZAxisSize)\r
+ public void setSZ(double d) {\r
+ this.sz = d;\r
+ firePropertyChanged(CSG.URIs.HasZAxisSize);\r
+ }\r
+ \r
+ @RelatedGetValue(CSG.URIs.HasXAxisSize)\r
+ @GetPropertyValue(value=CSG.URIs.HasXAxisSize, name = "X Size")\r
+ public double getSx() {\r
+ return sx;\r
+ }\r
+ \r
+ @RelatedGetValue(CSG.URIs.HasYAxisSize)\r
+ @GetPropertyValue(value=CSG.URIs.HasYAxisSize, name = "Y Size")\r
+ public double getSy() {\r
+ return sy;\r
+ }\r
+ \r
+ @RelatedGetValue(CSG.URIs.HasZAxisSize)\r
+ @GetPropertyValue(value=CSG.URIs.HasZAxisSize, name = "Z Size")\r
+ public double getSz() {\r
+ return sz;\r
+ }\r
+ \r
+ \r
+ @Override\r
+ public TopoDS_Shape getBaseGeometry() {\r
+ return OccTriangulator.makeBox(-sx * 0.5, -sy * 0.5, -sz * 0.5, sx * 0.5, sy * 0.5, sz * 0.5);\r
+ }\r
+\r
+\r
+}\r