/*////////////////////////////////////////////////////////////////////////////// // CMT Cosmic Muon Tomography project ////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// Copyright (c) 2014, Universita' degli Studi di Padova, INFN sez. di Padova All rights reserved Authors: Andrea Rigoni Garola < andrea.rigoni@pd.infn.it > ------------------------------------------------------------------ This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3.0 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library. //////////////////////////////////////////////////////////////////////////////*/ #ifndef VTKQUADMESH_H #define VTKQUADMESH_H #include "Math/QuadMesh.h" #include "Vtk/uLibVtkInterface.h" #include "Vtk/vtkPolydata.h" class vtkPolyData; class vtkActor; namespace uLib { namespace Vtk { class vtkQuadMesh : public Puppet, public Polydata { typedef QuadMesh Content; public: vtkQuadMesh(Content &content); ~vtkQuadMesh(); void ReadFromFile(const char *filename); void ReadFromXMLFile(const char *filename); void ReadFromObjFile(const char *filename); void ReadFromStlFile(const char *filename); virtual class vtkPolyData *GetPolyData() const; virtual void contentUpdate(); virtual void Update(); private: void vtk2uLib_update(); void uLib2vtk_update(); QuadMesh &m_content; vtkPolyData *m_Poly; vtkActor *m_Actor; }; } // namespace Vtk } // namespace uLib #endif // VTKQUADMESH_H