From d040b9f9d62f33723b026133fcc75183c12710f9 Mon Sep 17 00:00:00 2001 From: Robert Osfield Date: Wed, 11 Mar 2009 12:08:24 +0000 Subject: [PATCH] From Lionel Lagarde, "the attachment contains a correction of the Optimizer::MergeGeometryVisitor. When 2 geometries are merged, the primitive sets of the second geometry are copied to the first geometry. The primitive sets were copied with a std::insert into the first geometry primitive set vector. It doesn't work when the geometry is using VBOs (because the element buffer object of the primitive set is not updated). The correction replaces lhs.getPrimitiveSetList().insert( lhs.getPrimitiveSetList().end(), rhs.getPrimitiveSetList().begin(), rhs.getPrimitiveSetList().end() ); by for( primItr=rhs.getPrimitiveSetList().begin(); primItr!=rhs.getPrimitiveSetList().end(); ++primItr ) { lhs.addPrimitiveSet(primItr->get()); }" --- src/osgUtil/Optimizer.cpp | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/osgUtil/Optimizer.cpp b/src/osgUtil/Optimizer.cpp index 435c63ef0..3f3499d2b 100644 --- a/src/osgUtil/Optimizer.cpp +++ b/src/osgUtil/Optimizer.cpp @@ -2445,11 +2445,11 @@ bool Optimizer::MergeGeometryVisitor::mergeGeometry(osg::Geometry& lhs,osg::Geom // shift the indices of the incoming primitives to account for the pre existing geometry. - for(osg::Geometry::PrimitiveSetList::iterator primItr=rhs.getPrimitiveSetList().begin(); - primItr!=rhs.getPrimitiveSetList().end(); - ++primItr) + osg::Geometry::PrimitiveSetList::iterator primItr; + for(primItr=rhs.getPrimitiveSetList().begin(); primItr!=rhs.getPrimitiveSetList().end(); ++primItr) { osg::PrimitiveSet* primitive = primItr->get(); + switch(primitive->getType()) { case(osg::PrimitiveSet::DrawElementsUBytePrimitiveType): @@ -2516,12 +2516,12 @@ bool Optimizer::MergeGeometryVisitor::mergeGeometry(osg::Geometry& lhs,osg::Geom primitive->offsetIndices(base); break; } - - } - lhs.getPrimitiveSetList().insert(lhs.getPrimitiveSetList().end(), - rhs.getPrimitiveSetList().begin(),rhs.getPrimitiveSetList().end()); + for(primItr=rhs.getPrimitiveSetList().begin(); primItr!=rhs.getPrimitiveSetList().end(); ++primItr) + { + lhs.addPrimitiveSet(primItr->get()); + } lhs.dirtyBound(); lhs.dirtyDisplayList();