Open Inventor Reference
SoLineSet.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright (C) 2000 Silicon Graphics, Inc. All Rights Reserved.
4  *
5  * This library is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU Lesser General Public
7  * License as published by the Free Software Foundation; either
8  * version 2.1 of the License, or (at your option) any later version.
9  *
10  * This library is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  * Lesser General Public License for more details.
14  *
15  * Further, this software is distributed without any warranty that it is
16  * free of the rightful claim of any third person regarding infringement
17  * or the like. Any license provided herein, whether implied or
18  * otherwise, applies only to this software file. Patent licenses, if
19  * any, provided herein do not apply to combinations of this program with
20  * other software, or any other product whatsoever.
21  *
22  * You should have received a copy of the GNU Lesser General Public
23  * License along with this library; if not, write to the Free Software
24  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25  *
26  * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
27  * Mountain View, CA 94043, or:
28  *
29  * http://www.sgi.com
30  *
31  * For further information regarding this notice, see:
32  *
33  * http://oss.sgi.com/projects/GenInfo/NoticeExplan/
34  *
35  */
36 
37 
38 /*
39  * Copyright (C) 1990,91 Silicon Graphics, Inc.
40  *
41  _______________________________________________________________________
42  ______________ S I L I C O N G R A P H I C S I N C . ____________
43  |
44  | $Revision: 1.1.1.1 $
45  |
46  | Description:
47  | This file defines the SoLineSet node class.
48  |
49  | Author(s) : Paul S. Strauss
50  |
51  ______________ S I L I C O N G R A P H I C S I N C . ____________
52  _______________________________________________________________________
53  */
54 
55 #ifndef _SO_LINE_SET_
56 #define _SO_LINE_SET_
57 
61 
62 class SoState;
63 
64 
65 
66 #ifndef IV_STRICT
70 #define SO_LINE_SET_USE_REST_OF_VERTICES (-1)
71 #endif
72 
73 
76 
144 
146 
148 
149  public:
151 
152  SoMFInt32 numVertices;
154 
157 
160 
162 
165 
166  SoEXTENDER public:
168  virtual void GLRender(SoGLRenderAction *action);
169 
171  virtual void getBoundingBox(SoGetBoundingBoxAction *action);
172 
173  SoINTERNAL public:
174  static void initClass();
175 
177  enum Binding {
178  OVERALL, PER_LINE, PER_SEGMENT, PER_VERTEX
179  };
180 
183  typedef void (SoLineSet::*PMLS)(SoGLRenderAction *);
184 
185  protected:
187  virtual void generatePrimitives(SoAction *action);
188 
190  virtual void computeBBox(SoAction *action, SbBox3f &box,
191  SbVec3f &center);
192 
195  const SoPrimitiveVertex *v1,
196  const SoPrimitiveVertex *v2,
197  SoPickedPoint *pp);
198 
199  virtual ~SoLineSet();
200 
201  private:
203  void GLRenderInternal( SoGLRenderAction * action, uint32_t useTexCoordsAnyway, const SoShapeStyleElement * shapeStyle);
204 
206  static Binding getMaterialBinding(SoAction *action);
207  static Binding getNormalBinding(SoAction *action);
208 
212  bool wouldGenerateNormals(SoState *state);
213 
215  virtual void notify(SoNotList *list);
216 
222  int totalNumVertices;
223 
230  void OmOn(SoGLRenderAction *); void OmOnT(SoGLRenderAction *);
231  void OmPn(SoGLRenderAction *); void OmPnT(SoGLRenderAction *);
232  void OmFn(SoGLRenderAction *); void OmFnT(SoGLRenderAction *);
233  void OmVn(SoGLRenderAction *); void OmVnT(SoGLRenderAction *);
234  void PmOn(SoGLRenderAction *); void PmOnT(SoGLRenderAction *);
235  void PmPn(SoGLRenderAction *); void PmPnT(SoGLRenderAction *);
236  void PmFn(SoGLRenderAction *); void PmFnT(SoGLRenderAction *);
237  void PmVn(SoGLRenderAction *); void PmVnT(SoGLRenderAction *);
238  void FmOn(SoGLRenderAction *); void FmOnT(SoGLRenderAction *);
239  void FmPn(SoGLRenderAction *); void FmPnT(SoGLRenderAction *);
240  void FmFn(SoGLRenderAction *); void FmFnT(SoGLRenderAction *);
241  void FmVn(SoGLRenderAction *); void FmVnT(SoGLRenderAction *);
242  void VmOn(SoGLRenderAction *); void VmOnT(SoGLRenderAction *);
243  void VmPn(SoGLRenderAction *); void VmPnT(SoGLRenderAction *);
244  void VmFn(SoGLRenderAction *); void VmFnT(SoGLRenderAction *);
245  void VmVn(SoGLRenderAction *); void VmVnT(SoGLRenderAction *);
246 
248  static PMLS renderFunc[32];
249 
250 };
251 
252 #endif /* _SO_LINE_SET_ */
#define SoEXTENDER
Provide inline template functions for abs, swap, min, max, and clamp.
Definition: SbBasic.h:154
#define SoINTERNAL
Definition: SbBasic.h:155
#define INVENTOR_API
Disable some annoying warnings on MSVC 6.
Definition: SbSystem.h:81
unsigned int uint32_t
Definition: SbTypeDefs.h:44
#define SO_NODE_HEADER(className)
Non-abstract classes have everything abstract classes have, plus a way to create an instance.
Definition: SoSubNode.h:170
3D box class.
Definition: SbBox.h:81
3D vector class.
Definition: SbLinear.h:120
Abstract base class for all actions.
Definition: SoAction.h:179
Base class for describing detail information about a shape node.
Definition: SoDetail.h:78
Renders a scene graph using OpenGL.
Computes bounding box of a scene.
Polyline shape node.
Definition: SoLineSet.h:145
virtual void generatePrimitives(SoAction *action)
Generates line segments representing line set.
Binding
This enum is used to indicate the current material or normal binding.
Definition: SoLineSet.h:177
SoLineSet()
Creates a line set node with default settings.
virtual SoDetail * createLineSegmentDetail(SoRayPickAction *action, const SoPrimitiveVertex *v1, const SoPrimitiveVertex *v2, SoPickedPoint *pp)
Overrides standard method to create an SoLineDetail instance.
SoSFBool independentLines
If enabled, GL_LINES are drawn for all vertice pairs, independent of the numVertices field (MeVis Onl...
Definition: SoLineSet.h:159
virtual ~SoLineSet()
virtual void GLRender(SoGLRenderAction *action)
Implements actions.
SoSFBool sendAdjacency
flag that defines if the GL_LINE_STRIP_ADJACENCY draw mode is used (MeVis Only)
Definition: SoLineSet.h:156
static void initClass()
virtual void getBoundingBox(SoGetBoundingBoxAction *action)
Redefine this to tell open caches that they contain lines.
virtual void computeBBox(SoAction *action, SbBox3f &box, SbVec3f &center)
Computes bounding box of line set.
Multiple-value field containing any number of int32_t integers.
Definition: SoMFInt32.h:81
Abstract base class for all non-indexed vertex-based shapes.
Holds a list of SoNotRec notification records.
Represents point on surface of picked object.
Definition: SoPickedPoint.h:89
Represents a vertex of a generated primitive.
Intersects objects with a ray cast into scene.
Field containing a single boolean value.
Definition: SoSFBool.h:78
This elements stores some information shapes need to quickly determine whether or not they should ren...
An SoState collects and holds state while traversing a scene graph.
Definition: SoState.h:82
virtual void notify(SoNotList *list)
Redefines this to invalidate normal cache.