我是VTK的新手。 这是我的代码的一部分:
vtkDataSetReader *rdr = vtkDataSetReader::New();
rdr->SetFileName("proj7b.vtk");
rdr->SetScalarsName("hardyglobal");
rdr->Update();
int dims[3];
vtkRectilinearGrid *rgrid = (vtkRectilinearGrid *) rdr->GetOutput();
rgrid->GetDimensions(dims);
vtkDataArray *dataArray;
dataArray = vtkDoubleArray::New();
dataArray = rgrid->GetPointData()->GetScalars()->GetVoidPointer(0);
for(i=0;i<10;i++)
{
cout<<"here----------"<<endl;
cout<<" "<<dataArray[i]<<" ";
}
我想将数据读入我的vtkDataArray。但是这段代码无法编译:
proj7b.cxx:525:15: error:
assigning to 'vtkDataArray *' from incompatible type 'void *'
dataArray = rgrid->GetPointData()->GetScalars()->GetVoidPointer(0);
^ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
生成1个错误。 有没有人知道如何将数据读入vtkDataArray?
答案 0 :(得分:1)
Vtk为它提供了方法,你不需要使用“低级”方法:
rgrid-&GT; GetPointData() - &GT;的getArray(0)
或 rgrid-&GT; GetPointData() - &GT;的getArray( “arrayName中”)
它对FieldData和CellData(http://www.vtk.org/doc/release/6.2/html/classvtkFieldData.html)
的工作方式相同你得到的是一个vtkArray,而不是一个简单的c ++数组,所以你必须阅读它:
cout<<" "<<dataArray->GetValue(i) <<" ";
中有很多例子