BestMPRBaseVtk-007-给测试程序增加3D体渲染

简介: BestMPRBaseVtk-007-给测试程序增加3D体渲染

image.png

BestMPRBaseVtk 给测试程序增加3D体渲染

上一篇不是把图像的

显示方向问题解决了吗,后面博士让我搞一下鼠标事件,最近有点神烦的,不想搞,正好我的测试程序准备完善一点,把原来vtkImageViewer2的位置给他换了,换成一个3D的。


文章目录


BestMPRBaseVtk 给测试程序增加3D体渲染

增加3D体渲染

演示效果

☞ 源码

关键字: vtkContourFilter、vtkPolyDataNormals、vtkPolyDataMapper、vtkActor、vtkRenderer


增加3D体渲染


其实3D渲染整体还是vtk的标准流水线原则数据->过滤器->映射器->Actor ->渲染器->Window+交互器,理解起来简答,搞起来难。


那么久直接上代码


 //读取Dicom文件
    vtkSmartPointer<vtkDICOMImageReader> reader = vtkSmartPointer<vtkDICOMImageReader>::New();
    reader->SetDirectoryName(url);
    reader->SetDataSpacing(3.2, 1.5, 1.5);
    reader->Update();
    //这是一个过滤器,官方翻译如下
    //vtkContourFilter是一个过滤器,它将任何数据集作为输入,并在输出等值面和/或等值线上生成。
    //输出的确切形式取决于输入数据的维数。 由3D单元格组成的数据将生成等值面,由2D单元格组成的数据将生成等值线,
    //由1D或0D单元格组成的数据将生成等点。 如果输入维度是混合的,输出类型的组合是可能的。
    //若要使用此筛选器,必须指定一个或多个轮廓值。 您可以使用SetValue()方法来指定每个轮廓值,也可以使用GenerateValues()来生成一系列均匀间隔的轮廓。
    //还可以通过使用vtkScalarTree来加速这个过滤器的操作(以额外的内存为代价)。 标量树用于快速定位包含轮廓曲面的单元。 这是特别有效的,如果多个轮廓被提取。
    //如果您想要使用标量树,请调用方法UseScalarTreeOn()。
    vtkSmartPointer<vtkContourFilter> skinExtractor = vtkSmartPointer<vtkContourFilter>::New();
    skinExtractor->SetInputConnection(reader->GetOutputPort());
    skinExtractor->SetValue(0, 500);
    //vtkPolyDataNormals是一个为多边形网格计算点和/或单元法线的过滤器。
    //用户通过设置ComputeCellNormals和ComputePointNormals标志来指定他们是否希望计算点和/或单元格法线。
    vtkSmartPointer<vtkPolyDataNormals> skinNormals = vtkSmartPointer<vtkPolyDataNormals>::New();
    skinNormals->SetInputConnection(skinExtractor->GetOutputPort());
    skinNormals->SetFeatureAngle(60.0);
    vtkSmartPointer<vtkPolyDataMapper> skinMapper = vtkSmartPointer<vtkPolyDataMapper>::New();
    skinMapper->SetInputConnection(skinNormals->GetOutputPort());
    skinMapper->ScalarVisibilityOff();
    vtkSmartPointer<vtkActor> skin = vtkSmartPointer<vtkActor>::New();
    skin->SetMapper(skinMapper);
    vtkSmartPointer<vtkRenderer> aRenderer = vtkSmartPointer<vtkRenderer>::New();
    aRenderer->SetBackground(0, 0, 0);
    aRenderer->ResetCameraClippingRange();
    ui->openGLWidget->renderWindow()->AddRenderer(aRenderer);
    aRenderer->AddActor(skin);
    ui->openGLWidget->renderWindow()->Render();

image.pngimage.png

目录
相关文章
|
2月前
|
SQL 安全 测试技术
Web应用程序安全测试
Web应用程序安全测试
|
2月前
|
存储 缓存 监控
Web 应用程序性能测试核心步骤
Web 应用程序性能测试核心步骤
|
8月前
|
算法 异构计算
基于FPGA的Lorenz混沌系统verilog开发,含testbench和matlab辅助测试程序
基于FPGA的Lorenz混沌系统verilog开发,含testbench和matlab辅助测试程序
|
2月前
|
Linux Android开发
测试程序之提供ioctl函数应用操作GPIO适用于Linux/Android
测试程序之提供ioctl函数应用操作GPIO适用于Linux/Android
33 0
|
9月前
|
算法 异构计算
m基于FPGA的gardner环定时同步实现,含testbench测试程序
m基于FPGA的gardner环定时同步实现,含testbench测试程序
120 0
|
2月前
|
开发框架 测试技术 定位技术
如何开展移动应用程序性能测试?
如何开展移动应用程序性能测试?
|
10天前
|
运维 监控 大数据
部署-Linux01,后端开发,运维开发,大数据开发,测试开发,后端软件,大数据系统,运维监控,测试程序,网页服务都要在Linux中进行部署
部署-Linux01,后端开发,运维开发,大数据开发,测试开发,后端软件,大数据系统,运维监控,测试程序,网页服务都要在Linux中进行部署
|
18天前
|
SQL 存储 Java
程序技术好文:软件工程概论第一次课堂测试
程序技术好文:软件工程概论第一次课堂测试
|
2月前
|
测试技术
LabVIEW程序测试
LabVIEW程序测试
20 1
|
2月前
|
监控 测试技术 持续交付
Python自动化测试代理程序可用性
总之,通过编写测试用例、自动化测试和设置监控系统,您可以确保Python自动化测试代理程序的可用性,并及时发现和解决问题。这有助于提供更可靠和高性能的代理服务。
29 4

相关实验场景

更多