37#ifdef G4VIS_BUILD_OI_DRIVER
45#include <Inventor/SbBox.h>
46#include <Inventor/fields/SoSFFloat.h>
47#include <Inventor/misc/SoChildList.h>
48#include <Inventor/nodes/SoSeparator.h>
49#include <Inventor/nodes/SoCube.h>
50#include <Inventor/nodes/SoScale.h>
51#include <Inventor/actions/SoAction.h>
52#include <Inventor/nodes/SoIndexedFaceSet.h>
53#include <Inventor/SoPrimitiveVertex.h>
54#include <Inventor/elements/SoTextureCoordinateElement.h>
62 SO_NODE_CONSTRUCTOR(
SoBox);
65 SO_NODE_ADD_FIELD(fDx, (1.0));
66 SO_NODE_ADD_FIELD(fDy, (1.0));
67 SO_NODE_ADD_FIELD(fDz, (1.0));
68 SO_NODE_ADD_FIELD(alternateRep, (NULL));
69 children =
new SoChildList(
this);
81 static bool first =
true;
84 SO_NODE_INIT_CLASS(
SoBox,SoShape,
"Shape");
95 SoState *state = action->getState();
99 SbBool useTexFunction=
100 (SoTextureCoordinateElement::getType(state) ==
101 SoTextureCoordinateElement::FUNCTION);
106 const SoTextureCoordinateElement *tce = NULL;
108 if (useTexFunction) {
109 tce = SoTextureCoordinateElement::getInstance(state);
115 SbVec3f point, normal;
120#define GEN_VERTEX(pv,x,y,z,s,t,nx,ny,nz) \
121 point.setValue(x,y,z); \
122 normal.setValue(nx,ny,nz); \
123 if (useTexFunction) { \
124 texCoord=tce->get(point,normal); \
130 pv.setPoint(point); \
131 pv.setNormal(normal); \
132 pv.setTextureCoords(texCoord); \
137 const int NPOINTS=8, NFACES=6, NINDICES = NFACES*5;
138 int indices[NINDICES] = {3,2,1,0, SO_END_FACE_INDEX,
139 4,5,6,7, SO_END_FACE_INDEX,
140 0,1,5,4, SO_END_FACE_INDEX,
141 1,2,6,5, SO_END_FACE_INDEX,
142 2,3,7,6, SO_END_FACE_INDEX,
143 3,0,4,7, SO_END_FACE_INDEX};
147 float points[NPOINTS][3];
148 points[0][0] =
fDx.getValue();
149 points[0][1] =
fDy.getValue();
150 points[0][2] = -
fDz.getValue();
152 points[1][0] = -
fDx.getValue();
153 points[1][1] =
fDy.getValue();
154 points[1][2] = -
fDz.getValue();
156 points[2][0] = -
fDx.getValue();
157 points[2][1] = -
fDy.getValue();
158 points[2][2] = -
fDz.getValue();
160 points[3][0] =
fDx.getValue();
161 points[3][1] = -
fDy.getValue();
162 points[3][2] = -
fDz.getValue();
164 points[4][0] =
fDx.getValue();
165 points[4][1] =
fDy.getValue();
166 points[4][2] =
fDz.getValue();
168 points[5][0] = -
fDx.getValue();
169 points[5][1] =
fDy.getValue();
170 points[5][2] =
fDz.getValue();
172 points[6][0] = -
fDx.getValue();
173 points[6][1] = -
fDy.getValue();
174 points[6][2] =
fDz.getValue();
176 points[7][0] =
fDx.getValue();
177 points[7][1] = -
fDy.getValue();
178 points[7][2] =
fDz.getValue();
180 float normals[NFACES][3];
182 normals[0][0] = 0 ; normals[0][1] = 0; normals [0][2] = -1;
184 normals[1][0] = 0 ; normals[1][1] = 0; normals [1][2] = 1;
186 normals[2][0] = 0 ; normals[2][1] = 1; normals [2][2] = 0;
188 normals[3][0] = -1 ; normals[3][1] = 0; normals [3][2] = 0;
190 normals[4][0] = 0 ; normals[4][1] = -1; normals [4][2] = 0;
192 normals[5][0] = 1 ; normals[5][1] = 0; normals [5][2] = 0;
196 for (
int nf=0;nf<NFACES;nf++) {
197 beginShape(action,TRIANGLE_FAN);
198 index = indices[nf * 5];
199 x = points[index][0];
200 y = points[index][1];
201 z = points[index][2];
202 GEN_VERTEX(pv,x,y,z,0.0,0.0,normals[nf][0],normals[nf][1],normals[nf][2]);
203 index = indices[nf * 5 + 1];
204 x = points[index][0];
205 y = points[index][1];
206 z = points[index][2];
207 GEN_VERTEX(pv,x,y,z,0.0,0.0,normals[nf][0],normals[nf][1],normals[nf][2]);
208 index = indices[nf * 5 + 2];
209 x = points[index][0];
210 y = points[index][1];
211 z = points[index][2];
212 GEN_VERTEX(pv,x,y,z,0.0,0.0,normals[nf][0],normals[nf][1],normals[nf][2]);
213 index = indices[nf * 5 + 3];
214 x = points[index][0];
215 y = points[index][1];
216 z = points[index][2];
217 GEN_VERTEX(pv,x,y,z,0.0,0.0,normals[nf][0],normals[nf][1],normals[nf][2]);
230 SbVec3f vmin(-
fDx.getValue(),-
fDy.getValue(),-
fDz.getValue()),
231 vmax(
fDx.getValue(),
fDy.getValue(),
fDz.getValue());
232 center.setValue(0,0,0);
233 box.setBounds(vmin,vmax);
240void SoBox::updateChildren() {
245 assert(children->getLength()==1);
246 SoSeparator *sep = (SoSeparator *) ( *children)[0];
247 SoScale *scale = (SoScale *)( sep->getChild(0));
249 scale->scaleFactor.setValue(
fDx.getValue(),
fDy.getValue(),
fDz.getValue());
253void SoBox::generateChildren() {
258 assert(children->getLength() ==0);
259 SoSeparator *sep =
new SoSeparator();
260 SoScale *scale =
new SoScale();
261 SoCube *cube =
new SoCube();
263 sep->addChild(scale);
265 children->append(sep);
274 if (children->getLength() == 0) generateChildren();
SoBox()
Constructor, required.
SoSFFloat fDx
Half-length along X.
virtual void generateAlternateRep()
SoSFNode alternateRep
Alternate rep - for use by users without HEPVis shared objects.
SoSFFloat fDy
Half-length along Y.
virtual SoChildList * getChildren() const
GetChildList, required whenever the class has hidden children.
virtual ~SoBox()
Destructor, required.
SoSFFloat fDz
Half-length along Z.
static void initClass()
Class Initializer, required.
virtual void computeBBox(SoAction *action, SbBox3f &box, SbVec3f ¢er)
compute bounding Box, required
virtual void generatePrimitives(SoAction *action)
Generate Primitives, required.
virtual void clearAlternateRep()
We better be able to clear it, too!