使用vtkGenericDataObjectReader读入.vtk二进制文件

时间:2014-03-08 21:58:44

标签: c++ vtk

我正在尝试用c ++读取遗留的.vtk文件,并使用vtkGenericDataObjectReader填充我的数据结构(用于分子动力学模拟)。我搜索了文档,并将类似的SO问题的答案纳入其中,但我仍然误解了一些问题。这是文件。原谅二进制文件,我认为它写的正确,但我不排除它作为问题。

# vtk DataFile Version 3.0
vtk output
BINARY
DATASET POLYDATA
FIELD FieldData 2
TIME 1 1  double
\00\00\00\00\00\00\00\00CYCLE 1 1 int
\00\00\00\00POINTS 8 double
\BF\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2\BF\F0\ED\E4m    \D3B2?\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2\BF\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2?\F0\ED\E4m\D3B2VERTICES 8 16
\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00POINT_DATA 8
SCALARS mass  double
LOOKUP_TABLE default
@H\00\00\00\00\00\00@H\00\00\00\00\00\00@H\00\00\00\00\00\00@H\00\00\00\00\00\00@H\00\00\00\00\00\00@H\00\00\00\00\00\00@H\00\00\00\00\00\00@H\00\00\00\00\00\00VECTORS velocity  double
\BF\C0\9E   b\D8_\BFp\B4Mz\8B\BF\C1\A3|9?\B5\81`\FA\CAk?\C7N\A4ig\BF\94\E5R,\BE瀿\C5wSbK\8E?\98l?\E0\AFϿ\CC3\81\EE\F1n*\BF\C3\DA6\EArf?\B5Ж\CD\EF\99?\C1\F1,\9E\F3\CF?\99=Aɕm"?\B2\87l\89\96eU?\A9\E9cA\A4[?\BD\D6\FD\A2Ϳ\C5\E9r}\93\B1\BF\B8X:a\B86\A4?\BDB\CE\DBV֓\BF\A4\AAa,~,?Č7\CCR{?\BC\F4\99L\B7Y\BF\C3\CD    W\E4v(?\BFOS\D4f\8B

这是我的代码。在尝试执行'int rv = reader-> ReadPoints(ps,int(num_particles));'

vtkSmartPointer<vtkGenericDataObjectReader> reader = 
      vtkSmartPointer<vtkGenericDataObjectReader>::New();
reader->SetFileName(in_rel_path.c_str());
reader->Update();

vtkPolyData* output = reader->GetPolyDataOutput();
vtkPointSet *ps = NULL;
size_t num_particles = output->GetNumberOfPoints();
int rv = reader->ReadPoints(ps, int(num_particles));

vtkPointData* pd = output->GetPointData();
vtkDoubleArray* vel_data = vtkDoubleArray::SafeDownCast(pd->GetVectors());
vtkDoubleArray* mass_data = vtkDoubleArray::SafeDownCast(pd->GetScalars());
vtkDoubleArray* time_data = vtkDoubleArray::SafeDownCast(pd->GetArray("TIME"));
vtkIntArray* cycle_data = vtkIntArray::SafeDownCast(pd->GetArray("CYCLE"));

tot_iters = cycle_data->GetValue(0);
particles.resize(0);
double* position = new double[3];
double* velocity = new double[3];
for( size_t i = 0; i < num_particles; i++ )
{
  ps->GetPoint(int(i), position);
  vel_data->GetTupleValue(int(i), velocity);
  double pmass = mass_data->GetValue(int(i));
  particles.push_back(Particle(vec3(position[0],position[1],position[2]),
                 vec3(velocity[0],velocity[1],velocity[2]),
             pmass));
}
delete[] position;
delete[] velocity;

我承认我对VTK了解不多。如果有人能帮助解释我做错了什么,或者更好的解决方法,我真的很感激。

1 个答案:

答案 0 :(得分:1)

读取PolyData的最佳选择是使用vtkPolyDataReader类。 但是如果你阅读了类文档,他们会给出关于BINARY文件的以下警告 “在一个系统上写入的二进制文件可能在其他系统上无法读取。”

这是一个来自VTK Wiki的例子,它读取.vtk文件

#include <vtkPolyDataReader.h>
#include <vtkSmartPointer.h>
#include <vtkPolyDataMapper.h>
#include <vtkActor.h>
#include <vtkRenderWindow.h>
#include <vtkRenderer.h>
#include <vtkRenderWindowInteractor.h>

int main ( int argc, char *argv[] )
{
   // Parse command line arguments
   if(argc != 2)
   {
   std::cerr << "Usage: " << argv[0]
             << " Filename(.vtk)" << std::endl;
   return EXIT_FAILURE;
   }

   std::string filename = argv[1];  

   // Read all the data from the file
  vtkSmartPointer<vtkPolyDataReader> reader =
  vtkSmartPointer<vtkPolyDataReader>::New();
  reader->SetFileName(filename.c_str());
  reader->Update();

  // Visualize
  vtkSmartPointer<vtkPolyDataMapper> mapper =
  vtkSmartPointer<vtkPolyDataMapper>::New();
  mapper->SetInputConnection(reader->GetOutputPort());

  vtkSmartPointer<vtkActor> actor = vtkSmartPointer<vtkActor>::New(); 
  actor->SetMapper(mapper);

  vtkSmartPointer<vtkRenderer> renderer =
  vtkSmartPointer<vtkRenderer>::New();
  vtkSmartPointer<vtkRenderWindow> renderWindow =
  vtkSmartPointer<vtkRenderWindow>::New();
  renderWindow->AddRenderer(renderer);
  vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor =
  vtkSmartPointer<vtkRenderWindowInteractor>::New();
  renderWindowInteractor->SetRenderWindow(renderWindow);

  renderer->AddActor(actor);
  renderer->SetBackground(.3, .6, .3); // Background color green

  renderWindow->Render();
  renderWindowInteractor->Start();

  return EXIT_SUCCESS;
}