00001 /*===========================================================================*\ 00002 * * 00003 * OpenFlipper * 00004 * Copyright (C) 2001-2009 by Computer Graphics Group, RWTH Aachen * 00005 * www.openflipper.org * 00006 * * 00007 *---------------------------------------------------------------------------* 00008 * This file is part of OpenFlipper. * 00009 * * 00010 * OpenFlipper is free software: you can redistribute it and/or modify * 00011 * it under the terms of the GNU Lesser General Public License as * 00012 * published by the Free Software Foundation, either version 3 of * 00013 * the License, or (at your option) any later version with the * 00014 * following exceptions: * 00015 * * 00016 * If other files instantiate templates or use macros * 00017 * or inline functions from this file, or you compile this file and * 00018 * link it with other files to produce an executable, this file does * 00019 * not by itself cause the resulting executable to be covered by the * 00020 * GNU Lesser General Public License. This exception does not however * 00021 * invalidate any other reasons why the executable file might be * 00022 * covered by the GNU Lesser General Public License. * 00023 * * 00024 * OpenFlipper is distributed in the hope that it will be useful, * 00025 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00026 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00027 * GNU Lesser General Public License for more details. * 00028 * * 00029 * You should have received a copy of the GNU LesserGeneral Public * 00030 * License along with OpenFlipper. If not, * 00031 * see <http://www.gnu.org/licenses/>. * 00032 * * 00033 \*===========================================================================*/ 00034 00035 /*===========================================================================*\ 00036 * * 00037 * $Revision: 8521 $ * 00038 * $Author: moebius $ * 00039 * $Date: 2010-02-10 15:57:35 +0100 (Mi, 10. Feb 2010) $ * 00040 * * 00041 \*===========================================================================*/ 00042 00043 00044 00045 00046 //============================================================================= 00047 // 00048 // CLASS TriStripNodeT 00049 // 00050 //============================================================================= 00051 00052 00053 #ifndef ACG_TRISTRIPNODET_HH 00054 #define ACG_TRISTRIPNODET_HH 00055 00056 00057 //== INCLUDES ================================================================= 00058 00059 00060 #include "MeshNodeT.hh" 00061 00062 #include <OpenMesh/Tools/Utils/StripifierT.hh> 00063 00064 00065 //== NAMESPACES =============================================================== 00066 00067 00068 namespace ACG { 00069 namespace SceneGraph { 00070 00071 00072 //== CLASS DEFINITION ========================================================= 00073 00074 00075 00081 template <class Mesh> 00082 class TriStripNodeT : public MeshNodeT<Mesh> 00083 { 00084 public: 00085 00086 typedef OpenMesh::StripifierT<Mesh> MyStripifier; 00087 typedef MeshNodeT<Mesh> Base; 00088 typedef typename Base::FaceMode FaceMode; 00089 00090 00092 TriStripNodeT(Mesh& _mesh, 00093 BaseNode* _parent=0, 00094 std::string _name="<TriStripNodeT>" ) 00095 : Base(_mesh, _parent, _name), 00096 strips_(_mesh) 00097 {} 00098 00099 00101 ~TriStripNodeT() {} 00102 00103 00104 ACG_CLASSNAME(TriStripNodeT); 00105 00106 00108 void update_strips() 00109 { 00110 std::vector<unsigned int>().swap(Base::indices_); 00111 strips_.stripify(); 00112 } 00113 00114 00116 virtual void update_topology() 00117 { 00118 strips_.clear(); 00119 Base::update_topology(); 00120 } 00121 00122 00123 00124 private: 00125 00126 virtual void draw_faces(FaceMode _mode) 00127 { 00128 if (Base::mesh_.is_trimesh() && 00129 _mode == Base::PER_VERTEX && 00130 strips_.is_valid()) 00131 { 00132 typename MyStripifier::StripsIterator strip_it = strips_.begin(); 00133 typename MyStripifier::StripsIterator strip_last = strips_.end(); 00134 00135 for (; strip_it!=strip_last; ++strip_it) 00136 glDrawElements(GL_TRIANGLE_STRIP, 00137 strip_it->size(), 00138 GL_UNSIGNED_INT, 00139 &(*strip_it)[0] ); 00140 } 00141 else Base::draw_faces(_mode); 00142 } 00143 00144 00145 MyStripifier strips_; 00146 }; 00147 00148 00149 //============================================================================= 00150 } // namespace SceneGraph 00151 } // namespace ACG 00152 //============================================================================= 00153 #endif // ACG_TRISTRIPNODET_HH defined 00154 //============================================================================= 00155