minor changes in visulizing of selected tetrahedra

This commit is contained in:
Nico Pietroni 2004-10-06 16:24:59 +00:00
parent c803df0f82
commit 1852feab38
1 changed files with 35 additions and 3 deletions

View File

@ -205,9 +205,15 @@ template <ColorMode cm >
} }
glBegin(GL_TRIANGLES); glBegin(GL_TRIANGLES);
for( it = tetra.begin(); it != tetra.end(); ++it) for( it = tetra.begin(); it != tetra.end(); ++it)
if(!(*it).IsD()){ if((!it->IsD())&&(!(it->IsS()))) //draw as normal
{
_DrawSmallTetra<cm>(*it); _DrawSmallTetra<cm>(*it);
} }
else
if((!it->IsD())&&(!(it->IsS())))//draw in selection mode
{
_DrawSelectedTetra(*it);
}
glEnd(); glEnd();
glPopAttrib(); glPopAttrib();
} }
@ -252,10 +258,34 @@ void _DrawSurface(){
glPopAttrib(); glPopAttrib();
} }
void _DrawSelectedTetra(TetraType &t)
{
glPushMatrix();
glPushAttrib(0xffff);
glDisable(GL_CLIP_PLANE0);
glDisable(GL_BLEND);
glDisable(GL_LIGHTING);
glDisable(GL_NORMALIZE);
glPolygonMode(GL_FRONT_AND_BACK,GL_LINE);
glBegin(GL_LINE_LOOP);
glColor3d(1,0,0);
for (int face=0;face<4;face++)
{
glVertex(t.V(Tetra::VofF(face,0))->P());
glVertex(t.V(Tetra::VofF(face,1))->P());
glVertex(t.V(Tetra::VofF(face,2))->P());
}
//end drawing
glPopAttrib();
glPopMatrix();
}
template <DrawMode dm,NormalMode nm,ColorMode cm > template <DrawMode dm,NormalMode nm,ColorMode cm >
void _DrawTetra(TetraType &t) void _DrawTetra(TetraType &t)
{ {
if(!(t.IsD())) if((!t.IsD())&&(!t.IsS()))
{ {
if ((dm!=DMWire)&&(dm!=DMHidden)) if ((dm!=DMWire)&&(dm!=DMHidden))
_ChooseColorTetra<cm>(t); _ChooseColorTetra<cm>(t);
@ -265,7 +295,6 @@ void _DrawTetra(TetraType &t)
else else
{ {
if (t.IsBorderF(i)) if (t.IsBorderF(i))
//if (t.IsS())
{ {
if(nm==NMSmooth) if(nm==NMSmooth)
_DrawFaceSmooth<cm>(t,i); _DrawFaceSmooth<cm>(t,i);
@ -276,6 +305,9 @@ void _DrawTetra(TetraType &t)
} }
} }
} }
else
if((!t.IsD())&&(t.IsS()))
_DrawSelectedTetra(t);
} }
template <ColorMode cm > template <ColorMode cm >