Main Page   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Related Pages  

Triangles.cpp

Go to the documentation of this file.
00001 
00002 /*
00003     TEDDY - General graphics application library
00004     Copyright (C) 1999-2002  Timo Suoranta
00005     tksuoran@cc.helsinki.fi
00006 
00007     This library is free software; you can redistribute it and/or
00008     modify it under the terms of the GNU Lesser General Public
00009     License as published by the Free Software Foundation; either
00010     version 2.1 of the License, or (at your option) any later version.
00011 
00012     This library is distributed in the hope that it will be useful,
00013     but WITHOUT ANY WARRANTY; without even the implied warranty of
00014     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00015     Lesser General Public License for more details.
00016 
00017     You should have received a copy of the GNU Lesser General Public
00018     License along with this library; if not, write to the Free Software
00019     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00020 
00021     $Id:  $
00022 */
00023 
00024 
00025 #include "Teddy/Models/Triangles.h"
00026 #include "Teddy/Models/Vertex.h"
00027 #include "Teddy/PhysicalComponents/Projection.h"
00028 #include "Teddy/SysSupport/Messages.h"
00029 #include "Teddy/SysSupport/StdIO.h"
00030 using namespace Teddy::SysSupport;
00031 
00032 
00033 namespace Teddy  {
00034 namespace Models {
00035 
00036 
00038 Triangles::Triangles(){
00039 }
00040 
00041 
00043 /*virtual*/ Triangles::~Triangles(){
00044 }
00045 
00046 
00048 /*virtual*/ void Triangles::draw( Projection *p ){
00049 
00050     /*if( isEnabled(EL_USE_ELEMENT_NORMAL|EL_HAS_ELEMENT_NORMAL) ){
00051         dmsg( M_INIT, "Drawing flat triangles" );
00052 
00053         p->beginTriangles();
00054 
00055         list<Vector*>::const_iterator  n_it  = normals .begin();
00056         list<Vertex*>::const_iterator  v1_it = vertices.begin();
00057         list<Vertex*>::const_iterator  v2_it = v1_it;
00058         Vertex                        *v0    = *v1_it++;
00059         while( n_it != normals.end() && v2_it != vertices.end() ){
00060             Vector *normal = *n_it++;
00061             p->normal( *normal );
00062             v0->draw( p );
00063             v2_it = v1_it;
00064             (*v2_it++)->draw( p ); if( v2_it == vertices.end() ){ dmsg( M_WARN, "TriangleFan missing vertices" ); break; }
00065             (*v2_it++)->draw( p );
00066             v1_it++;
00067         }
00068 
00069         p->end();
00070 
00071     }else{*/
00072         dmsg( M_INIT, "Drawing smoothed triangles" );
00073 
00074         p->beginTriangles();
00075         list<Vertex*>::const_iterator v_it = vertices.begin();
00076         while( v_it != vertices.end() ){
00077             (*v_it)->draw( p );
00078             v_it++;
00079         }
00080 
00081         p->end();
00082     //}
00083 
00084 }
00085 
00086 
00087 //  CSG
00088 /*virtual*/ unsigned long Triangles::countCSGFaceElements(){
00089     unsigned long size = vertices.size();
00090     return size / 3;
00091 }
00092 
00093 
00094 };  //  namespace Models
00095 };  //  namespace Teddy
00096