日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

VTK修炼之道38:图像平滑_中值滤波器

發(fā)布時(shí)間:2025/3/15 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 VTK修炼之道38:图像平滑_中值滤波器 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1.中值濾波

vtkImageHybridMedian2D實(shí)現(xiàn)了對(duì)二維圖像的中值濾波。其實(shí)現(xiàn)原理是,采用一個(gè)5x5的模板,逐次將模板中心對(duì)應(yīng)于圖像的每個(gè)像素上,將模板圖像覆蓋的像素的中值作為當(dāng)前像素的輸出值。

#include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL);#include <vtkSmartPointer.h> #include <vtkJPEGReader.h> #include <vtkImageData.h> #include <vtkImageCast.h> #include <vtkImageHybridMedian2D.h> #include <vtkImageActor.h> #include <vtkRenderer.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h> #include <vtkInteractorStyleImage.h>int main(int argc, char* argv[]) {vtkSmartPointer<vtkJPEGReader> reader =vtkSmartPointer<vtkJPEGReader>::New();reader->SetFileName("lena.jpg");reader->Update();vtkSmartPointer<vtkImageHybridMedian2D> hybridMedian =vtkSmartPointer<vtkImageHybridMedian2D>::New();hybridMedian->SetInputData(reader->GetOutput());hybridMedian->Update();///vtkSmartPointer<vtkImageActor> originalActor =vtkSmartPointer<vtkImageActor>::New();originalActor->SetInputData(reader->GetOutput());vtkSmartPointer<vtkImageActor> hybridMedianActor =vtkSmartPointer<vtkImageActor>::New();hybridMedianActor->SetInputData(hybridMedian->GetOutput());/double originalViewport[4] = { 0.0, 0.0, 0.5, 1.0 };double hybridMedianViewport[4] = { 0.5, 0.0, 1.0, 1.0 };vtkSmartPointer<vtkRenderer> originalRenderer =vtkSmartPointer<vtkRenderer>::New();originalRenderer->SetViewport(originalViewport);originalRenderer->AddActor(originalActor);originalRenderer->ResetCamera();originalRenderer->SetBackground(1.0,0,0);vtkSmartPointer<vtkRenderer> hybridMedianRenderer =vtkSmartPointer<vtkRenderer>::New();hybridMedianRenderer->SetViewport(hybridMedianViewport);hybridMedianRenderer->AddActor(hybridMedianActor);hybridMedianRenderer->ResetCamera();hybridMedianRenderer->SetBackground(1.0, 1.0, 1.0);//vtkSmartPointer<vtkRenderWindow> rw =vtkSmartPointer<vtkRenderWindow>::New();rw->AddRenderer(originalRenderer);rw->AddRenderer(hybridMedianRenderer);rw->SetSize(640, 320);rw->Render();rw->SetWindowName("MedianFilterExample");vtkSmartPointer<vtkRenderWindowInteractor> rwi =vtkSmartPointer<vtkRenderWindowInteractor>::New();vtkSmartPointer<vtkInteractorStyleImage> style =vtkSmartPointer<vtkInteractorStyleImage>::New();rwi->SetInteractorStyle(style);rwi->SetRenderWindow(rw);rwi->Initialize();rwi->Start();return 0; }


該類使用非常簡(jiǎn)單,不需要用戶設(shè)置任何參數(shù)。該方法能夠有效的保持圖像邊緣,并對(duì)于椒鹽噪聲有較好的抑制作用。對(duì)于三維圖像,則使用vtkImageHybridMedian3D類。

執(zhí)行結(jié)果如下:



2.參考資料

1.《C++ primer》
2.《The VTK User’s Guide – 11thEdition》
3. ?張曉東, 羅火靈. VTK圖形圖像開發(fā)進(jìn)階[M]. 機(jī)械工業(yè)出版社, 2015.

總結(jié)

以上是生活随笔為你收集整理的VTK修炼之道38:图像平滑_中值滤波器的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。