VTK修炼之道55:图形基本操作进阶_表面重建技术(等值面提取)
生活随笔
收集整理的這篇文章主要介紹了
VTK修炼之道55:图形基本操作进阶_表面重建技术(等值面提取)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.等值面提取
等值面(線)提取是一種常用的可視化技術,常應用于醫學、地質、氣象等領域。例如,在醫學圖像處理中,由于CT、MRI等圖像分辨率越來越高,雖然體繪制技術可以清晰地對數據內部結構進行可視化,但是其計算量和效率卻制約了其使用。此時可通過等值面提取技術,僅提取感興趣的一個或者幾個組織輪廓,并生成網格模型以供后續的處理和研究。 根據數據類型的不同,VTK中提供了多個等值面提取類,其類圖如圖所示:VTK中的等值面提取算法多基于MarchingCube算法來實現。MarchingCube是經典的移動立方體等值面提取算法。該算法是由W.E.Lorenson和H.E.Cline在1987年提出的。由于這一方法原理簡單,易于實現,目前已經得到了較為廣泛的應用,稱為三維數據等值面生成的經典算法。等值面提取類根據數據類型的不同而有所側重。
- vtkImageMarchingCubes:主要處理三維圖像數據
- vtkMarchingCubes:主要針對規則體數據生成等值面
- vtkMarchingSquares:則是針對二維規則網格數據生成等值線
- vtkMarchingContourFilter:可以接受任何類型的數據,其內部根據數據不同生成不同的算法對象實現等值面/線的提取,具有較高的效率
- vtkContourFilter:則是一個更加通用的等值面提取類,其可以接受任意的數據類型生成等值線或等值面。
2.vtkMarchingCubes用于等值線提取實驗
上面的幾個類的使用方法基本一致,下面僅以vtkMarchingCubes為例來演示提取圖像數據等值面的效果: #include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL); 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("HeadMRVolume.mhd");reader->Update();vtkSmartPointer<vtkMarchingCubes> surface =vtkSmartPointer<vtkMarchingCubes>::New();surface->SetInputData(reader->GetOutput());surface->ComputeNormalsOn();surface->SetValue(0, 100); //第0個等值面 值為:200surface->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);
其中,numContour為生成等值面的個數,range表示獲取等勢面數值的范圍。 其實,這里面還有一個求取法向量的過程,我們可能會感到比較奇怪??! 通過前面分析的內容,我們知道,法向量可以提高渲染質量。
3.?cannot convert parameter 1 from 'vtkImageData *' to 'vtkDataObject *'
在vtkuser里看到有人提問了。解決方法很簡單:
增加頭文件:
#include "vtkImageData.h"即可
4.一直以來未解決的問題
貌似一直以來除了我,沒有人遇到過啊???其實在32bit平臺上也沒有遇到過。。。繼續吧。。。
5.參看資料
1.《C++ primer》2.《The VTK User’s Guide – 11thEdition》
3. ?張曉東, 羅火靈. VTK圖形圖像開發進階[M]. 機械工業出版社, 2015.
總結
以上是生活随笔為你收集整理的VTK修炼之道55:图形基本操作进阶_表面重建技术(等值面提取)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 每个人对工作都会有自己的想法
- 下一篇: 携号转网将于明年在全国范围内实施