vtk实战(十四)——解析vtk XML 文件的内容

对于vtk XML格式的文件: .vtu, .vtp, .vts, .vtr, .vti, .vto, 解析其存储单元、单元数据。

#include <vtkSmartPointer.h>
#include <vtkXMLReader.h>
#include <vtkXMLUnstructuredGridReader.h>
#include <vtkXMLPolyDataReader.h>
#include <vtkXMLStructuredGridReader.h>
#include <vtkXMLRectilinearGridReader.h>
#include <vtkXMLHyperOctreeReader.h>
#include <vtkXMLCompositeDataReader.h>
#include <vtkXMLStructuredGridReader.h>
#include <vtkXMLImageDataReader.h>
#include <vtkDataSetReader.h>
#include <vtkDataSet.h>
#include <vtkUnstructuredGrid.h>
#include <vtkRectilinearGrid.h>
#include <vtkHyperOctree.h>
#include <vtkImageData.h>
#include <vtkPolyData.h>
#include <vtkStructuredGrid.h>
#include <vtkPointData.h>
#include <vtkCellData.h>
#include <vtkFieldData.h>
#include <vtkCellTypes.h>
#include <vtksys\SystemTools.hxx>

template<class TReader> vtkDataSet *ReadAnXMLFile(const char*fileName);

int main()
{
    char *argv[5];
    argv[0] = "cow.vtp";
    argv[1] = "cth.vtr";
    argv[2] = "chombo3d_1.vti";
    argv[3] = "multicomb_1.vts";
    argv[4] = "quadraticTetra01.vtu"; 
    int f = 0;
    while (f < 5)
    {
        vtkDataSet *dataSet;
        std::string extension =

        vtksys::SystemTools::GetFilenameLastExtension(argv[f]);
        if (extension == ".vtu")
        {
            dataSet = ReadAnXMLFile<vtkXMLUnstructuredGridReader>(argv[f]);
        }
        else if (extension == ".vtp")
        {
            dataSet = ReadAnXMLFile<vtkXMLPolyDataReader>(argv[f]);
        }
        else if (extension == ".vts")
        {
            dataSet = ReadAnXMLFile<vtkXMLStructuredGridReader>(argv[f]);
        }
        else if (extension == ".vtr")
        {
            dataSet = ReadAnXMLFile<vtkXMLRectilinearGridReader>(argv[f]);
        }
        else if (extension == ".vti")
        {
            dataSet = ReadAnXMLFile<vtkXMLImageDataReader>(argv[f]);
        }
        else if (extension == ".vto")
        {
            dataSet = ReadAnXMLFile<vtkXMLHyperOctreeReader>(argv[f]);
        }
        else if (extension == ".vtk")
        {
            dataSet = ReadAnXMLFile<vtkDataSetReader>(argv[f]);
        }
        else
        {
            std::cerr << argv[0] << " Unknown extension: " << extension << std::endl;
            return EXIT_FAILURE;
        }

        int numberOfCells = dataSet->GetNumberOfCells();
        int numberOfPoints = dataSet->GetNumberOfPoints();

        std::cout << "------------------------" << std::endl;
        std::cout << argv[f] << std::endl
            << " contains a " << std::endl
            << dataSet->GetClassName()
            << " that has " << numberOfCells << " cells"
            << " and " << numberOfPoints << " points." << std::endl;
        typedef std::map<int, int> CellContainer;
        CellContainer cellMap;
        for (int i = 0; i < numberOfCells; i++)
        {
            cellMap[dataSet->GetCellType(i)]++;
        }

        CellContainer::const_iterator it = cellMap.begin();
        while (it != cellMap.end())
        {
            std::cout << "\tCell type "
                << vtkCellTypes::GetClassNameFromTypeId(it->first)
                << " occurs " << it->second << " times." << std::endl;
            ++it;
        }

        vtkPointData *pd = dataSet->GetPointData();
        if (pd)
        {
            std::cout << " contains point data with "
                << pd->GetNumberOfArrays()
                << " arrays." << std::endl;
            for (int i = 0; i < pd->GetNumberOfArrays(); i++)
            {
                std::cout << "\tArray " << i
                    << " is named "
                    << (pd->GetArrayName(i) ? pd->GetArrayName(i) : "NULL")
                    << std::endl;
            }
        }
        vtkCellData *cd = dataSet->GetCellData();
        if (cd)
        {
            std::cout << " contains cell data with "
                << cd->GetNumberOfArrays()
                << " arrays." << std::endl;
            for (int i = 0; i < cd->GetNumberOfArrays(); i++)
            {
                std::cout << "\tArray " << i
                    << " is named "
                    << (cd->GetArrayName(i) ? cd->GetArrayName(i) : "NULL")
                    << std::endl;
            }
        }
        // Now check for field data
        if (dataSet->GetFieldData())
        {
            std::cout << " contains field data with "
                << dataSet->GetFieldData()->GetNumberOfArrays()
                << " arrays." << std::endl;
            for (int i = 0; i < dataSet->GetFieldData()->GetNumberOfArrays(); i++)
            {
                std::cout << "\tArray " << i
                    << " is named " << dataSet->GetFieldData()->GetArray(i)->GetName()
                    << std::endl;
            }
        }
        dataSet->Delete();
        f++;
    }
    return 0;
}

template<class TReader> vtkDataSet *ReadAnXMLFile(const char*fileName)
{
    vtkSmartPointer<TReader> reader =
        vtkSmartPointer<TReader>::New();
    reader->SetFileName(fileName);
    reader->Update();
    reader->GetOutput()->Register(reader);
    return vtkDataSet::SafeDownCast(reader->GetOutput());
}

运行结果
代码链接:http://pan.baidu.com/s/1i4OPjjZ

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vtk(Visualization Toolkit)是一种用于可视化的开源软件包。要创建医学四视图,可以使用vtk进行以下步骤: 1. 导入必要的库和模块:首先,我们需要导入vtk库以及与医学图像处理相关的模块。例如,我们可以导入vtkImageReader、vtkImageViewer2、vtkRenderWindow和vtkRenderer等模块。 2. 加载医学图像:使用vtkImageReader来读取医学图像数据(例如DICOM文件),并将其加载到vtkImageData对象中。 3. 创建四个视图窗口:创建一个vtkRenderWindow,并在其上使用vtkRenderer来创建四个视窗,分别对应于医学四视图中的前、后、左、右视图。 4. 渲染和可视化:为每个视窗分配不同的视角和相机位置,然后将vtkImageData对象附加到对应的vtkImageViewer2对象中,并将其添加到相应的vtkRenderer中。 5. 显示图像:将vtkRenderWindow显示出来,可以使用vtkRenderWindowInteractor来提供交互功能,如放大、移动、旋转等。 通过上述步骤,我们可以使用vtk创建一个包含医学四视图的可视化界面。这些四个视图窗口将分别显示医学图像的前、后、左、右视图,使用户能够更清晰地了解医学图像的结构和细节。 值得一提的是,vtk有丰富的功能和灵活性,我们可以通过设置不同的参数和属性来自定义医学四视图的外观和交互方式,以满足特定的需求。同时,vtk还支持与其他库和工具进行集成,进一步扩展可视化和分析的能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值