当前位置 博文首页 > mdxiaohu的博客:整合QT、VTK、ITK联合开发的简单Demo

    mdxiaohu的博客:整合QT、VTK、ITK联合开发的简单Demo

    作者:[db:作者] 时间:2021-06-23 12:17

    前言:

    一般医学图像处理软件,

    所使用的是QT来用作界面UI设计。

    ITK进行算法的操作,例如分割。

    但是ITK不能用于显示

    所以就需要用VTK来显示等。

    本例子是一个简单的整合

    QT、VTK、ITK的一个Demo,

    以供需要的人参考。

    操作示例:

    程序运行图:

    QT版本:

    项目属性页:

    附录:

    搭建好环境,程序可以运行。

    这里可以检测下VTK和ITK是否配置好。

    ITK测试程序:

    #include "itkImage.h"
    #include <iostream>
    
    
    int main()
    {
    	using ImageType = itk::Image< unsigned short, 3 >;
    	ImageType::Pointer image = ImageType::New();
    	std::cout << "ITK Hello World !" << std::endl;
    	return EXIT_SUCCESS;
    }

    VTK测试程序:

     
    #include <vtkSphereSource.h>
     
    #include <vtkPolyData.h>
     
    #include <vtkSmartPointer.h>
     
    #include <vtkPolyDataMapper.h>
     
    #include <vtkActor.h>
     
    #include <vtkRenderWindow.h>
     
    #include <vtkRenderer.h>
     
    #include <vtkRenderWindowInteractor.h>
     
     
    #include "vtkAutoInit.h" 
    VTK_MODULE_INIT(vtkRenderingOpenGL2); // VTK was built with vtkRenderingOpenGL2
    VTK_MODULE_INIT(vtkInteractionStyle);
     
    int main(int, char *[])
     
    {
     
        // Create a sphere
     
        vtkSmartPointer<vtkSphereSource> sphereSource =
     
            vtkSmartPointer<vtkSphereSource>::New();
     
        sphereSource->SetCenter(0.0, 0.0, 0.0);
     
        sphereSource->SetRadius(5.0);
     
        //mapper
     
        vtkSmartPointer<vtkPolyDataMapper> mapper =
     
            vtkSmartPointer<vtkPolyDataMapper>::New();
     
        mapper->SetInputConnection(sphereSource->GetOutputPort());
     
        //actor
     
        vtkSmartPointer<vtkActor> actor =
     
            vtkSmartPointer<vtkActor>::New();
     
        actor->SetMapper(mapper);
     
        //renderer ,renderWindow, renderWindowInteractor.
     
        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;
     
    }

    可以自己测试下,自己的环境是否搭建好。

    项目下载

    工程文件下载地址:https://download.csdn.net/download/mdxiaohu/11079236

    链接:https://pan.baidu.com/s/1SGifpFxpXJ3fS0TF85tlIQ?
    提取码:2rmm?
    复制这段内容后打开百度网盘手机App,操作更方便哦