Commit 8eb31585 authored by Chris Cantwell's avatar Chris Cantwell

Added back deleted OutputVtk files.

parent b8a64877
////////////////////////////////////////////////////////////////////////////////
//
// File: OutputVtk.cpp
//
// For more information, please see: http://www.nektar.info/
//
// The MIT License
//
// Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
// Department of Aeronautics, Imperial College London (UK), and Scientific
// Computing and Imaging Institute, University of Utah (USA).
//
// License for the specific language governing rights and limitations under
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
// Description: VTK file format output.
//
////////////////////////////////////////////////////////////////////////////////
#include <set>
#include <string>
using namespace std;
#include <vtkPolyDataWriter.h>
#include <vtkPolyData.h>
#include <vtkPoints.h>
#include <vtkCellArray.h>
#include "MeshElements.h"
#include "OutputVtk.h"
namespace Nektar
{
namespace Utilities
{
ModuleKey OutputVtk::className =
GetModuleFactory().RegisterCreatorFunction(
ModuleKey(eOutputModule, "vtk"), OutputVtk::create,
"Writes a VTK file.");
OutputVtk::OutputVtk(MeshSharedPtr m) : OutputModule(m)
{
}
OutputVtk::~OutputVtk()
{
}
void OutputVtk::Process()
{
if (m_mesh->m_verbose)
{
cout << "OutputVtk: Writing file..." << endl;
}
vtkPolyData *vtkMesh = vtkPolyData::New();
vtkPoints *vtkPoints = vtkPoints::New();
vtkCellArray *vtkPolys = vtkCellArray::New();
std::set<NodeSharedPtr>::iterator it;
std::set<NodeSharedPtr> tmp(
m_mesh->m_vertexSet.begin(),
m_mesh->m_vertexSet.end());
for (it = tmp.begin(); it != tmp.end(); ++it)
{
NodeSharedPtr n = *it;
vtkPoints->InsertPoint(n->m_id, n->m_x, n->m_y, n->m_z);
}
vtkIdType p[8];
vector<ElementSharedPtr> &elmt =
m_mesh->m_element[m_mesh->m_expDim];
for(int i = 0; i < elmt.size(); ++i)
{
int vertexCount = elmt[i]->GetVertexCount();
for (int j = 0; j < vertexCount; ++j)
{
p[j] = elmt[i]->GetVertex(j)->m_id;
}
vtkPolys->InsertNextCell(vertexCount, &p[0]);
}
vtkMesh->SetPoints(vtkPoints);
vtkMesh->SetPolys(vtkPolys);
// Write out the new mesh
vtkPolyDataWriter *vtkMeshWriter = vtkPolyDataWriter::New();
vtkMeshWriter->SetFileName(m_config["outfile"].as<string>().c_str());
#if VTK_MAJOR_VERSION <= 5
vtkMeshWriter->SetInput(vtkMesh);
#else
vtkMeshWriter->SetInputData(vtkMesh);
#endif
vtkMeshWriter->Update();
}
}
}
////////////////////////////////////////////////////////////////////////////////
//
// File: OutputVtk.h
//
// For more information, please see: http://www.nektar.info/
//
// The MIT License
//
// Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
// Department of Aeronautics, Imperial College London (UK), and Scientific
// Computing and Imaging Institute, University of Utah (USA).
//
// License for the specific language governing rights and limitations under
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
// Description: Vtk output module
//
////////////////////////////////////////////////////////////////////////////////
#ifndef UTILITIES_PREPROCESSING_MESHCONVERT_OUTPUTVTK
#define UTILITIES_PREPROCESSING_MESHCONVERT_OUTPUTVTK
#include <tinyxml.h>
#include "Module.h"
namespace Nektar
{
namespace Utilities
{
/// Converter for Gmsh files.
class OutputVtk : public OutputModule
{
public:
/// Creates an instance of this class
static boost::shared_ptr<Module> create(MeshSharedPtr m) {
return MemoryManager<OutputVtk>::AllocateSharedPtr(m);
}
static ModuleKey className;
OutputVtk(MeshSharedPtr m);
virtual ~OutputVtk();
/// Write mesh to output file.
virtual void Process();
};
}
}
#endif
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment