日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發布時間:2025/3/15 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 VTK修炼之道55:图形基本操作进阶_表面重建技术(等值面提取) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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用于等值線提取實驗

上面的幾個類的使用方法基本一致,下面僅以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:图形基本操作进阶_表面重建技术(等值面提取)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 午夜香蕉视频 | 特级毛片在线观看 | 九九激情网 | 国产福利91精品 | 91香蕉国产在线观看软件 | 韩国三级黄色 | 日本欧美一本 | 国产精品成人免费 | 极品尤物一区二区 | 无码人妻丰满熟妇啪啪欧美 | 性无码专区无码 | 国产日韩精品一区 | www.国产在线视频 | 色综合狠狠 | 三级中文字幕在线 | 日韩黄色在线播放 | 日韩免费一级片 | 中文字幕在线免费看 | 成人区一区二区 | 日本国产在线播放 | 天天射天天干 | 亚洲精品大全 | 久久久久久无码精品人妻一区二区 | 成人av片免费看 | 好吊色网站 | 美女下部无遮挡 | 欧美寡妇性猛交 | 五月激情婷婷丁香 | 精品久久久在线观看 | 亚洲色图另类小说 | 色www.| 四虎一区二区 | 国产大片一区二区三区 | 日本三级精品 | 日本裸体动漫 | 国产伦精品一区二区三区在线观看 | 久久久老司机 | 亚洲熟区| 日韩激情文学 | 免费成人在线网站 | 国产精品呻吟 | 国色天香av| 都市激情男人天堂 | 久久88| 亚洲国产精品成人无码区 | 久久青青草原亚洲av无码麻豆 | 91在线一区二区三区 | 激情五月婷婷色 | 久热最新| 天堂在线 | 亚洲欧美日韩精品在线观看 | 国产a级片视频 | 亚洲成人黄 | 免费69视频 | 四虎精品 | 成人午夜视频免费观看 | 右手影院亚洲欧美 | www.精品在线 | 欧美在线视频你懂的 | av国产精品 | 色屁屁网站 | 毛片国产| 国产日产精品一区二区三区 | 日韩av在线影院 | 久草久草 | 女教师高潮黄又色视频 | 在线观看涩涩视频 | av电影一区二区三区 | 日韩色av| 99视频在线精品 | 强videoshd酒醉| 末路1997全集免费观看完整版 | 日韩精品在线免费观看 | 久久国产精彩视频 | 在线免费观看亚洲 | 亚洲精品字幕在线观看 | 一级片一区 | av中文网| 欧美美女在线 | 性色av蜜臀av色欲av | 日韩一区二区三区在线播放 | www.伊人.com | 我们好看的2018视频在线观看 | 最新毛片网 | 成人久久精品人妻一区二区三区 | 成人欧美视频在线观看 | 日本高清黄色电影 | 91欧美在线 | 久久久久久黄色 | 欧亚一级片 | 伊人网视频在线观看 | www.99av | 天堂av免费观看 | 三级在线看中文字幕完整版 | 黄色一级片一级片 | 亚色视频在线观看 | 久久亚洲成人 | 99reav| 综合久久国产 |