From c095f8efe67e1999ade5802ff93ef2ec6d8cec19 Mon Sep 17 00:00:00 2001 From: cignoni Date: Tue, 20 Apr 2010 01:01:13 +0000 Subject: [PATCH] added pushattrib/popattrib in the point rendering code of gl trimesh wrapper --- wrap/gl/trimesh.h | 45 +++++++++++++++++++++++---------------------- 1 file changed, 23 insertions(+), 22 deletions(-) diff --git a/wrap/gl/trimesh.h b/wrap/gl/trimesh.h index 87c7b9cc..d4ff8c3c 100644 --- a/wrap/gl/trimesh.h +++ b/wrap/gl/trimesh.h @@ -721,6 +721,7 @@ double CameraDistance(){ template void DrawPoints() { + glPushAttrib(GL_ENABLE_BIT | GL_POINT_BIT); glPointSize(GetHintParamf(HNPPointSize)); if (glPointParameterfv) { @@ -734,32 +735,32 @@ void DrawPoints() if(m->vn!=(int)m->vert.size()) { DrawPointsBase(); - return; } + else + { + // Perfect case, no deleted stuff, + // draw the vertices using vertex arrays + if (nm==NMPerVert) + { + glEnableClientState (GL_NORMAL_ARRAY); + glNormalPointer(GL_FLOAT,sizeof(typename MESH_TYPE::VertexType),&(m->vert.begin()->N()[0])); + } + if (cm==CMPerVert) + { + glEnableClientState (GL_COLOR_ARRAY); + glColorPointer(4,GL_UNSIGNED_BYTE,sizeof(typename MESH_TYPE::VertexType),&(m->vert.begin()->C()[0])); + } - // Perfect case, no deleted stuff, - // draw the vertices using vertex arrays - if (nm==NMPerVert) - { - glEnableClientState (GL_NORMAL_ARRAY); - glNormalPointer(GL_FLOAT,sizeof(typename MESH_TYPE::VertexType),&(m->vert.begin()->N()[0])); - } - if (cm==CMPerVert) - { - glEnableClientState (GL_COLOR_ARRAY); - glColorPointer(4,GL_UNSIGNED_BYTE,sizeof(typename MESH_TYPE::VertexType),&(m->vert.begin()->C()[0])); - } + glEnableClientState (GL_VERTEX_ARRAY); + glVertexPointer(3,GL_FLOAT,sizeof(typename MESH_TYPE::VertexType),&(m->vert.begin()->P()[0])); - glEnableClientState (GL_VERTEX_ARRAY); - glVertexPointer(3,GL_FLOAT,sizeof(typename MESH_TYPE::VertexType),&(m->vert.begin()->P()[0])); - - //glDrawElements(GL_POINTS ,m->vn,GL_UNSIGNED_INT, &(*indices.begin()) ); - glDrawArrays(GL_POINTS,0,m->vn); - - glDisableClientState (GL_VERTEX_ARRAY); - if (nm==NMPerVert) glDisableClientState (GL_NORMAL_ARRAY); - if (cm==CMPerVert) glDisableClientState (GL_COLOR_ARRAY); + glDrawArrays(GL_POINTS,0,m->vn); + glDisableClientState (GL_VERTEX_ARRAY); + if (nm==NMPerVert) glDisableClientState (GL_NORMAL_ARRAY); + if (cm==CMPerVert) glDisableClientState (GL_COLOR_ARRAY); + } + glPopAttrib(); return; }