1 /*---------------------------------------------------------------------------*\
5 * Copyright (C) 2000-2002 by the OpenSG Forum *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
15 * This library is free software; you can redistribute it and/or modify it *
16 * under the terms of the GNU Library General Public License as published *
17 * by the Free Software Foundation, version 2. *
19 * This library is distributed in the hope that it will be useful, but *
20 * WITHOUT ANY WARRANTY; without even the implied warranty of *
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
22 * Library General Public License for more details. *
24 * You should have received a copy of the GNU Library General Public *
25 * License along with this library; if not, write to the Free Software *
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
37 \*---------------------------------------------------------------------------*/
40 #ifndef _OSGMERGEGRAPHOP_H_
41 #define _OSGMERGEGRAPHOP_H_
46 #include "OSGGraphOp.h"
47 #include "OSGUtilDef.h"
48 #include "OSGAction.h"
52 /*! \ingroup GrpUtilGraphOp
53 \ingroup GrpLibOSGUtil
56 class OSG_UTIL_DLLMAPPING MergeGraphOp
: public GraphOp
58 /*========================== PUBLIC =================================*/
62 /*---------------------------------------------------------------------*/
66 typedef GraphOp Inherited
;
67 typedef MergeGraphOp Self
;
69 OSG_GEN_INTERNAL_MEMOBJPTR(MergeGraphOp
);
72 /*---------------------------------------------------------------------*/
73 /*! \name Classname */
76 static const char *getClassname(void) { return "MergeGraphOp"; };
79 /*---------------------------------------------------------------------*/
80 /*! \name Constructors */
83 static ObjTransitPtr
create(void);
85 virtual GraphOpTransitPtr
clone (void);
88 /*---------------------------------------------------------------------*/
89 /*! \name Main methods */
92 virtual bool traverse(Node
*node
);
95 /*---------------------------------------------------------------------*/
96 /*! \name Parameters */
99 void setParams(const std::string params
);
100 std::string
usage ( void );
103 /*========================= PROTECTED ===============================*/
107 /*---------------------------------------------------------------------*/
108 /*! \name Constructors/Destructor */
111 MergeGraphOp(const char* name
= "Merge");
112 virtual ~MergeGraphOp(void );
115 /*========================== PRIVATE ================================*/
119 // Use these params to transform tangent space vectors, just like normals.
120 bool _color_is_vector
;
121 bool _secondary_color_is_vector
;
122 bool _texcoord0_is_vector
;
123 bool _texcoord1_is_vector
;
124 bool _texcoord2_is_vector
;
125 bool _texcoord3_is_vector
;
127 bool mergeOnce(Node
*node
);
129 void makeExcludeList (Node
* node
);
130 void processGroups (Node
* const node
);
131 void processTransformations (Node
* const node
);
132 void processGeometries (Node
* const node
);
134 bool isLeaf (Node
* const node
);
135 bool isGroup (Node
* const node
);
137 Action::ResultE
excludeListEnter(Node
* const node
);
138 Action::ResultE
excludeListLeave(Node
* const node
, Action::ResultE res
);
140 Action::ResultE
traverseEnter(Node
* const node
);
141 Action::ResultE
traverseLeave(Node
* const node
, Action::ResultE res
);
144 typedef MergeGraphOp
*MergeGraphOpP
;
146 OSG_GEN_MEMOBJPTR(MergeGraphOp
);
150 #endif /* _OSGMERGEGRAPHOP_H_ */