OpenSceneGraph/include/osgUtil/TriStripVisitor

107 lines
3.2 KiB
Plaintext
Raw Normal View History

/* -*-c++-*- OpenSceneGraph - Copyright (C) 1998-2003 Robert Osfield
*
* This library is open source and may be redistributed and/or modified under
* the terms of the OpenSceneGraph Public License (OSGPL) version 0.0 or
* (at your option) any later version. The full license is in LICENSE file
* included with this distribution, and on the openscenegraph.org website.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* OpenSceneGraph Public License for more details.
*/
2001-09-20 05:19:47 +08:00
#ifndef OSGUTIL_TRISTRIPVISITOR
#define OSGUTIL_TRISTRIPVISITOR 1
#include <osg/NodeVisitor>
#include <osg/Geode>
#include <osg/Geometry>
2001-09-20 05:19:47 +08:00
#include <osgUtil/Optimizer>
2001-09-20 05:19:47 +08:00
#include <set>
2001-09-20 05:19:47 +08:00
namespace osgUtil {
/** A tri stripping visitor for converting Geometry surface primitives into tri strips.
* The current implemention is based upon Tanguy Fautre's triangulation code.
2001-09-20 05:19:47 +08:00
*/
class OSGUTIL_EXPORT TriStripVisitor : public osg::NodeVisitor
{
public:
/// default to traversing all children.
2004-08-02 22:42:20 +08:00
TriStripVisitor(Optimizer* =0) :
osg::NodeVisitor( osg::NodeVisitor::TRAVERSE_ALL_CHILDREN ),
_cacheSize( 16 ),
_minStripSize( 2 ),
_generateFourPointPrimitivesQuads ( false)
{}
2001-09-20 05:19:47 +08:00
/** Convert mesh primitives in Geometry into Tri Strips.
* Converts all primitive types except points
2001-09-20 05:19:47 +08:00
* and lines, linestrips which it leaves unchanged.
*/
void stripify(osg::Geometry& drawable);
2001-09-20 05:19:47 +08:00
/** Stripify (make into strips of tria or quads) the accumulated list of Geometry drawables.*/
void stripify();
/// Accumulate the Geometry drawables to make into strips.
2001-09-20 05:19:47 +08:00
virtual void apply(osg::Geode& geode);
inline void setCacheSize( unsigned int size )
{
_cacheSize = size;
}
inline unsigned int getCacheSize()
{
return _cacheSize;
}
inline const unsigned int getCacheSize() const
{
return _cacheSize;
}
inline void setMinStripSize( unsigned int size )
{
_minStripSize = size;
}
inline unsigned int getMinStripSize()
{
return _minStripSize;
}
inline const unsigned int getMinStripSize() const
{
return _minStripSize;
}
inline bool isOperationPermissibleForObject(const osg::Object* object) const
{
return _optimizer ? _optimizer->isOperationPermissibleForObject(object,osgUtil::Optimizer::TRISTRIP_GEOMETRY) : true;
}
void setGenerateFourPointPrimitivesQuads(bool flag) { _generateFourPointPrimitivesQuads = flag; }
bool getGenerateFourPointPrimitivesQuads() const { return _generateFourPointPrimitivesQuads; }
private:
typedef std::set<osg::Geometry*> GeometryList;
Optimizer* _optimizer;
unsigned int _cacheSize;
unsigned int _minStripSize;
GeometryList _geometryList;
bool _generateFourPointPrimitivesQuads;
2001-09-20 05:19:47 +08:00
};
}
2001-09-20 05:19:47 +08:00
#endif