1.等值面提取

  • 等值面(线)提取是一种常用的可视化技术,常应用于医学、地质、气象等领域。例如,在医学图像处理中,由于CT、MRI等图像分辨率越来越高,虽然体绘制技术可以清晰地对数据内部结构进行可视化,但是其计算量和效率却制约了其使用。此时可通过等值面提取技术,仅提取感兴趣的一个或者几个组织轮廓,并生成网格模型以供后续的处理和研究。
  • 根据数据类型的不同,VTK中提供了多个等值面提取类,其类图如图所示:
  • VTK中的等值面提取算法多基于MarchingCube算法来实现。MarchingCube是经典的移动立方体等值面提取算法。该算法是由W.E.Lorenson和H.E.Cline在1987年提出的。由于这一方法原理简单,易于实现,目前已经得到了较为广泛的应用,称为三维数据等值面生成的经典算法。等值面提取类根据数据类型的不同而有所侧重。
  • vtkImageMarchingCubes:主要处理三维图像数据
    vtkMarchingCubes:主要针对规则体数据生成等值面
    vtkMarchingSquares:则是针对二维规则网格数据生成等值线
    vtkMarchingContourFilter:可以接受任何类型的数据,其内部根据数据不同生成不同的算法对象实现等值面/线的提取,具有较高的效率
    vtkContourFilter:则是一个更加通用的等值面提取类,其可以接受任意的数据类型生成等值线或等值面。
    vtkDiscreteMarchingCubes继承自vtkMarchingCubes,主要针对Label图像,比如利用图像分割算法对医学图像进行分割后得到含有不同Label值得数据,每个Label对应一个组织,吐过想要得到其中一个或者几个组织的洛括模型,则可以考虑使用该类。

2.vtkMarchingCubes用于等值线提取实验

资源下载地址:https://github.com/pyvista/vtk-data/tree/master/Data
将.mhd文件和.raw文件放在同一个文件夹中。

#include <vtkAutoInit.h>
VTK_MODULE_INIT(vtkRenderingOpenGL2);
VTK_MODULE_INIT(vtkRenderingFreeType);
VTK_MODULE_INIT(vtkInteractionStyle);#include <vtkSmartPointer.h>
#include <vtkMetaImageReader.h>
#include <vtkImageData.h>
#include <vtkMarchingCubes.h>
#include <vtkPolyDataMapper.h>
#include <vtkActor.h>
#include <vtkProperty.h>
#include <vtkRenderer.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkInteractorStyleImage.h>
#include <vtkVoxelModeller.h>
int main()
{vtkSmartPointer<vtkMetaImageReader> reader =vtkSmartPointer<vtkMetaImageReader>::New();reader->SetFileName("data/HeadMRVolume.mhd");reader->Update();vtkSmartPointer<vtkMarchingCubes> surface =vtkSmartPointer<vtkMarchingCubes>::New();surface->SetInputData(reader->GetOutput());surface->ComputeNormalsOn();surface->SetValue(0, 100);  //第0个等值面  值为:100surface->Update();//surface->GenerateValues(0, 150, 200);///vtkSmartPointer<vtkPolyDataMapper> surfMapper =vtkSmartPointer<vtkPolyDataMapper>::New();surfMapper->SetInputConnection(surface->GetOutputPort());vtkSmartPointer<vtkActor> surfActor =vtkSmartPointer<vtkActor>::New();surfActor->SetMapper(surfMapper);surfActor->GetProperty()->SetColor(1, 0, 0);vtkSmartPointer<vtkRenderer> surfRender =vtkSmartPointer<vtkRenderer>::New();surfRender->AddActor(surfActor);surfRender->SetBackground(0, 0, 0);vtkSmartPointer<vtkRenderWindow> rw =vtkSmartPointer<vtkRenderWindow>::New();rw->AddRenderer(surfRender);rw->SetSize(640, 480);rw->SetWindowName("PolyData MarchingCubes");rw->Render();vtkSmartPointer<vtkRenderWindowInteractor> rwi =vtkSmartPointer<vtkRenderWindowInteractor>::New();vtkSmartPointer<vtkInteractorStyleImage> style =vtkSmartPointer<vtkInteractorStyleImage>::New();rwi->SetInteractorStyle(style);rwi->SetRenderWindow(rw);rwi->Initialize();rwi->Start();return 0;
}


首先,通过一个人reader对象来读取一副图像,并将输入到vtkMarchingCubes中,提取等值面时,最重要的是设置等值面的数值,SetValue()函数用于设置等值面的值,其第一个参数表示等值的序号,因此可以通过这个函数设置多个等值面值来提取多个等值面。另外我们也可以通过GenerateValues提取多个等值面。

void GenerateValues(int numContours,double range[2]);
void GenerateValues(int numContours, double rangStart, double rangeEnd);

VTK:图形基本操作进阶——表面重建技术(等值面提取)相关推荐

  1. VTK:图形基本操作进阶——点云配准技术(LandMark标记点算法和坐标系显示方法)

    1.点配准 在计算机逆向工程中,通过三维扫描等实物数字化技术可以获取各种点云数据.但是受到测量环境和设备的影响,再一次测量的情况下,难以获得实物整体的点云数据,因此需要多次从不同的角度进行测量.但是不 ...

  2. VTK修炼之道54:图形基本操作进阶_表面重建技术(三角剖分)

    1.表面重建 通过三维扫描仪所获取的实际物体的空间点云数据仅仅表示物体的几何形状,而无法表达其内部的拓扑结构.拓扑结构对于实际图形处理以及可视化具有更重要的意义.因此,这就需要利用表面重建技术奖点云数 ...

  3. VTK_Learning_图形基本操作进阶_表面重建技术(三角剖分)

    1.表面重建 通过三维扫描仪所获取的实际物体的空间点云数据仅仅表示物体的几何形状,而无法表达其内部的拓扑结构.拓扑结构对于实际图形处理以及可视化具有更重要的意义.因此,这就需要利用表面重建技术奖点云数 ...

  4. VTK修炼之道55:图形基本操作进阶_表面重建技术(等值面提取)

    1.等值面提取 等值面(线)提取是一种常用的可视化技术,常应用于医学.地质.气象等领域.例如,在医学图像处理中,由于CT.MRI等图像分辨率越来越高,虽然体绘制技术可以清晰地对数据内部结构进行可视化, ...

  5. VTK修炼之道56:图形基本操作进阶_表面重建技术(三维点云曲面重建)

    1.点云重建 虽然Delaunay三角剖分算法可以实现网格曲面重建,但是其应用主要在二维剖分,在三维空间网格生成中遇到了问题.因为在三维点云曲面重建中,Delaunay条件不在满足,不仅基于最大最小角 ...

  6. VTK修炼之道49:图形基本操作进阶_网格平滑(点云的曲面重建技术)

    1.网格平滑 现代扫描技术的发展使得获取点云数据不再困难,通过曲线重建技术可以获取表面网格来表示各种复杂的实体.但是点云数据中往往存在噪声,这样得到的重建网格通常都需要进行平滑处理. 拉普拉斯平滑是一 ...

  7. VTK修炼之道57:图形基本操作进阶_点云配准技术(LandMark标记点算法和坐标系显示方法)

    1.点云配准 在计算机逆向工程中,通过三维扫描等实物数字化技术可以获取各种点云数据.但是受到测量环境和设备的影响,再一次测量的情况下,难以获取实物整体的点云数据,因此需要多次从不同角度进行测量.但不同 ...

  8. VTK修炼之道58:图形基本操作进阶_点云配准技术(迭代最近点ICP算法)

    1.Iterative Closest Points算法 点云数据配准最经典的方法是迭代最近点算法(Iterative Closest Points,ICP).ICP算法是一个迭代的过程,每次迭代中对 ...

  9. VTK修炼之道59:图形基本操作进阶_纹理映射

    1.纹理映射 纹理映射是将纹理空间中的纹理像素映射到屏幕空间中的像素的过程.纹理生成过程实质上是将所定义的纹理映射为某种三维物体表面的属性,并参与后续的光照计算.在三维图形中,纹理映射运用的十分广泛, ...

  10. VTK修炼之道48:图形基本操作进阶_符号化操作与模型区率计算

    1.符号化Glyphing再谈 上一篇帖子提到一个事,就是用符号化操作显示单元的法向量. 模型的法向量数据是向量数据,因此法向量不能像前面讲到的通过颜色映射来显示.但是可以通过符号化(Glyphing ...

最新文章

  1. .Net并行库介绍——Task(1)
  2. 虚拟机Linux中判断用户输入的是 Yes 或 NO
  3. 创业公司CEO每天应该做的13件事
  4. 从源码分析DEARGUI之add_selectable
  5. Matlab中Ksdensity()函数的用途 (2011-04-02 16:55:17)
  6. Intel MKL FATAL ERROR: Cannot load libmkl_avx2.so or libmkl_def.so.
  7. qemu模拟imx6用户态环境
  8. 【数据集下载神器】体验1000+优质数据集极速下载
  9. 推荐算法炼丹笔记:序列化推荐算法SASRec
  10. 在Vrep中如何创建基于QT的GUI
  11. 吴恩达《机器学习》第六章:逻辑回归
  12. 华为数据之道_DT|华为数据之道,怕你学不会,这次干脆出了本书
  13. 色差类染疵原因的详细分析
  14. 【ABAP系列】SAP ABAP 从FTP服务器读取文件到本地
  15. 微型计算机系统视频适配器为,计算机硬件基础1-微型计算机系统组成(含教材6,8,9章内容).ppt...
  16. 机器学习中的决策树算法
  17. MATLAB函数拟合使用
  18. 利用python暴力破解rar压缩文件密码
  19. Logstash详解之——input模块
  20. 双组百分比堆积柱形图的制作

热门文章

  1. 易康(eCognition)对象几何特征--1:几何(Geometry)_范围(Extent)
  2. 若干个数据首尾相连,构成一个圆环,找到连续的4个数之和最大的一段。
  3. oracle ap tp是什么,AP模式和Router模式区别是什么
  4. Sketchfab模型在ThingJS上的应用
  5. 加权算数平均大于等于几何平均
  6. 针式打印机色带选购知识要点解说
  7. 通过Vue解决跨域问题(proxy配置代理)
  8. 会使您势不可挡的程序员的行为
  9. java知识点ppt背景图片_Java 给 PowerPoint 文档添加背景颜色和背景图片
  10. 1179: 带参宏定义(函数专题)