00001 //--------------------------------------------------------------------------- 00002 // 00003 // Project: OpenWalnut ( http://www.openwalnut.org ) 00004 // 00005 // Copyright 2009 OpenWalnut Community, BSV@Uni-Leipzig and CNCF@MPI-CBS 00006 // For more information see http://www.openwalnut.org/copying 00007 // 00008 // This file is part of OpenWalnut. 00009 // 00010 // OpenWalnut is free software: you can redistribute it and/or modify 00011 // it under the terms of the GNU Lesser General Public License as published by 00012 // the Free Software Foundation, either version 3 of the License, or 00013 // (at your option) any later version. 00014 // 00015 // OpenWalnut is distributed in the hope that it will be useful, 00016 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00018 // GNU Lesser General Public License for more details. 00019 // 00020 // You should have received a copy of the GNU Lesser General Public License 00021 // along with OpenWalnut. If not, see <http://www.gnu.org/licenses/>. 00022 // 00023 //--------------------------------------------------------------------------- 00024 00025 #ifndef WWRITERFIBERVTK_H 00026 #define WWRITERFIBERVTK_H 00027 00028 #include <string> 00029 00030 // Use filesystem version 2 for compatibility with newer boost versions. 00031 #ifndef BOOST_FILESYSTEM_VERSION 00032 #define BOOST_FILESYSTEM_VERSION 2 00033 #endif 00034 #include <boost/filesystem.hpp> 00035 #include <boost/shared_ptr.hpp> 00036 00037 #include "../WDataSetFiberVector.h" 00038 #include "../WDataSetFibers.h" 00039 #include "../WExportDataHandler.h" 00040 #include "WWriter.h" 00041 00042 /** 00043 * Writes a FiberVTK file. 00044 */ 00045 class OWDATAHANDLER_EXPORT WWriterFiberVTK : public WWriter // NOLINT 00046 { 00047 public: 00048 /** 00049 * Creates a writer object for FiberVTK file writing. 00050 * 00051 * \param path to the target file where stuff will be written to 00052 * \param overwrite If true existing files will be overwritten 00053 */ 00054 WWriterFiberVTK( const boost::filesystem::path& path, bool overwrite = false ); 00055 00056 /** 00057 * Writes a WDataSetFiberVector down to the previousely given file 00058 * 00059 * \param fiberDS The WDataSetFiberVector where the data is taken from 00060 */ 00061 void writeFibs( boost::shared_ptr< const WDataSetFiberVector > fiberDS ) const; 00062 00063 /** 00064 * Writes tracts of a WDataSetFibers to the previousely given file. 00065 * 00066 * \param fiberDS The tract data set 00067 */ 00068 void writeFibs( boost::shared_ptr< const WDataSetFibers > fiberDS ) const; 00069 00070 protected: 00071 private: 00072 }; 00073 00074 #endif // WWRITERFIBERVTK_H