00001 //------------------------------------------------------------------------------ 00002 // This file is part of the OpenStructure project <www.openstructure.org> 00003 // 00004 // Copyright (C) 2008-2011 by the OpenStructure authors 00005 // 00006 // This library is free software; you can redistribute it and/or modify it under 00007 // the terms of the GNU Lesser General Public License as published by the Free 00008 // Software Foundation; either version 3.0 of the License, or (at your option) 00009 // any later version. 00010 // This library is distributed in the hope that it will be useful, but WITHOUT 00011 // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS 00012 // FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more 00013 // details. 00014 // 00015 // You should have received a copy of the GNU Lesser General Public License 00016 // along with this library; if not, write to the Free Software Foundation, Inc., 00017 // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 00018 //------------------------------------------------------------------------------ 00019 #ifndef OST_MAP_ISO_GEN_HH 00020 #define OST_MAP_ISO_GEN_HH 00021 00022 /* 00023 Author: Ansgar Philippsen 00024 */ 00025 00026 #include <vector> 00027 #include <ost/geom/geom.hh> 00028 #include <ost/img/map.hh> 00029 00030 #include <ost/gfx/map_iso_prop.hh> 00031 00032 00033 namespace ost { namespace gfx { 00034 00035 namespace map_iso { 00036 00037 // this must match the signature in map_iso_spec.hh 00038 // \internal 00039 typedef void (*AddLF)(IndexedVertexArray& va, 00040 unsigned int vertex_id[12]); 00041 00042 typedef std::vector<AddLF> AddLFList; 00043 00044 } // map_iso ns 00045 00046 namespace impl { 00047 00048 // \internal 00049 class DLLEXPORT_OST_GFX IsosurfaceGenerator { 00050 public: 00051 // singleton 00052 static IsosurfaceGenerator& Instance(); 00053 00054 IsosurfaceGenerator(); 00055 00056 void Generate(const img::MapHandle& mh, IndexedVertexArray& va, float level); 00057 00058 void AddLF(uint code, IndexedVertexArray& va,unsigned int vertex_id[12]); 00059 00060 private: 00061 map_iso::AddLFList add_lf_func_; 00062 }; 00063 00064 }}} 00065 00066 #endif