zoukankan      html  css  js  c++  java
  • VTK GetScalarPointer() and GetScalarComponentAsFloat() not work

    I am using VTK 5.10.1 with VS 2010, and the following example does not work on my machine:

    http://www.vtk.org/Wiki/VTK/Examples/Cxx/ImageData/IterateImageData

    The erros said:

    vtkImageData [009B92A8]: Bad component index 1302176011

    I am not sure why this happened, and it should work since it is from the official document. However, the reality is that it does not work on my machine, neither GetScalarComponentAsFloat() or GetScalarComponentAsDouble() will work.

    So if we want to get the pixel data from vtkImageData, we need to find another way to do it. And we can get the data by accessing vtkDataArray, please see the following example code:

    #include <vtkVersion.h>
    #include <vtkSmartPointer.h>
    #include <vtkImageData.h>
    #include <vtkPointData.h>
    #include "vtkBMPReader.h"
    
    int main(int, char *[])
    {
        char * filename = "img.bmp";
        if( !filename  || strlen(filename) == 0 )
        {
            return -1;
        }
    
        vtkBMPReader * reader = vtkBMPReader::New();
        reader->SetFileName(filename);
        reader->Update();
    
        vtkSmartPointer<vtkImageData> image_data = reader->GetOutput();
    
        int* dims = image_data->GetDimensions();
        std::cout << "Dims: " << " x: " << dims[0] << " y: " << dims[1] << " z: " << dims[2] << std::endl;
        std::cout << "Number of points: " << image_data->GetNumberOfPoints() << std::endl;
        std::cout << "Number of cells: " << image_data->GetNumberOfCells() << std::endl;
        std::cout << "Number of scalar components: " << image_data->GetNumberOfScalarComponents() << std::endl;
    
        vtkDataArray *arr = image_data->GetPointData()->GetArray(0);
    
        // Retrieve the entries from the image data and print them to the screen
        for (int z = 0; z < dims[2]; z++)
        {
            for (int y = 0; y < dims[1]; y++)
            {
                for (int x = 0; x < dims[0]; x++)
                {
                    /* Change this
                    double* pixel = static_cast<double*>(imageData->GetScalarPointer(x,y,z));
                    // do something with v
                    std::cout << pixel[0] << " ";
                    */
                    double d[3];
                    arr->GetTuple(y * dims[0] + x, d);
                    std::cout << d[0] << " ";
                }
                std::cout << std::endl;
            }
            std::cout << std::endl;
        }
    
        return EXIT_SUCCESS;
    }
  • 相关阅读:
    ssh session 共享
    python 快速开启http服务
    GCC 默认头文件搜索路径
    GCC 部分单元测试编译失败
    随机森林与GBDT
    DecisionTree
    SVM
    KDDCUP CTR预测比赛总结
    剑指offer-java
    搜狗搜索日志传输与分析
  • 原文地址:https://www.cnblogs.com/grandyang/p/5331386.html
Copyright © 2011-2022 走看看