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
62class 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
154
157
160
162
165
166 SoEXTENDER public:
168 virtual void GLRender(SoGLRenderAction *action);
169
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:77
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.
SoMFInt32 numVertices
Number of vertices per polyline.
Definition SoLineSet.h:153
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.
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.