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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

VTK修炼之道33:边缘检测_Sobel算子

發布時間:2025/3/15 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 VTK修炼之道33:边缘检测_Sobel算子 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.Sobel算子用于提取圖像邊緣

Sobel算子也是一種常用的梯度算子。Sobel算子計算稍微復雜,它采用3x3的模板。計算時模板在圖像上移動,并在每個位置上計算對應中心像素的梯度值。
VTK中vtkSobel2D計算圖像的sobel算子,使用代碼如下: #include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL);#include <vtkSmartPointer.h> #include <vtkJPEGReader.h> #include <vtkImageSobel2D.h> #include <vtkImageExtractComponents.h> #include <vtkImageMathematics.h> #include <vtkImageData.h> #include <vtkImageShiftScale.h> #include <vtkImageActor.h> #include <vtkRenderer.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h> #include <vtkInteractorStyleImage.h>int main() {vtkSmartPointer<vtkJPEGReader> reader =vtkSmartPointer<vtkJPEGReader>::New();reader->SetFileName("lena.jpg");reader->Update();vtkSmartPointer<vtkImageSobel2D> sobelFilter =vtkSmartPointer<vtkImageSobel2D>::New();sobelFilter->SetInputConnection(reader->GetOutputPort());//包含橫向和豎向邊緣//提取X向邊緣成分vtkSmartPointer<vtkImageExtractComponents> xSobel =vtkSmartPointer<vtkImageExtractComponents>::New();xSobel->SetComponents(0);//提取第一成分即X向梯度xSobel->SetInputConnection(sobelFilter->GetOutputPort());xSobel->Update();vtkSmartPointer<vtkImageMathematics> absFilter =vtkSmartPointer<vtkImageMathematics>::New();absFilter->SetOperationToAbsoluteValue();//將屬性設置為絕對值模式absFilter->SetInputConnection(xSobel->GetOutputPort());absFilter->Update();double xRange[2];absFilter->GetOutput()->GetScalarRange(xRange);vtkSmartPointer<vtkImageShiftScale> xShiftScale =vtkSmartPointer<vtkImageShiftScale>::New();xShiftScale->SetOutputScalarTypeToUnsignedChar();//強制類型轉換 方便顯示xShiftScale->SetScale(255 / xRange[1]);//設置屬性xShiftScale->SetInputConnection(absFilter->GetOutputPort());xShiftScale->Update();//提取Y向邊緣成分vtkSmartPointer<vtkImageExtractComponents> ySobel =vtkSmartPointer<vtkImageExtractComponents>::New();ySobel->SetComponents(1);ySobel->SetInputConnection(sobelFilter->GetOutputPort());ySobel->Update();vtkSmartPointer<vtkImageMathematics> absYsobel =vtkSmartPointer<vtkImageMathematics>::New();absYsobel->SetOperationToAbsoluteValue();absYsobel->SetInputConnection(ySobel->GetOutputPort());absYsobel->Update();double yRange[2];absYsobel->GetOutput()->GetScalarRange(yRange);vtkSmartPointer<vtkImageShiftScale> yShiftScale =vtkSmartPointer<vtkImageShiftScale>::New();yShiftScale->SetOutputScalarTypeToUnsignedChar();yShiftScale->SetScale(255 / yRange[1]);yShiftScale->SetInputConnection(absYsobel->GetOutputPort());yShiftScale->Update();vtkSmartPointer<vtkImageActor> origActor =vtkSmartPointer<vtkImageActor>::New();origActor->SetInputData(reader->GetOutput());vtkSmartPointer<vtkImageActor> xSobelActor =vtkSmartPointer<vtkImageActor>::New();xSobelActor->SetInputData(xShiftScale->GetOutput());vtkSmartPointer<vtkImageActor> ySobelActor =vtkSmartPointer<vtkImageActor>::New();ySobelActor->SetInputData(yShiftScale->GetOutput());/double origView[4] = { 0, 0, 0.33, 1 };double xSobelView[4] = { 0.33, 0, 0.66, 1 };double ySobelView[4] = { 0.66, 0, 1, 1 };vtkSmartPointer<vtkRenderer> origRender =vtkSmartPointer<vtkRenderer>::New();origRender->SetViewport(origView);origRender->AddActor(origActor);origRender->ResetCamera();origRender->SetBackground(1, 0, 0);vtkSmartPointer<vtkRenderer> xSobelRender =vtkSmartPointer<vtkRenderer>::New();xSobelRender->SetViewport(xSobelView);xSobelRender->AddActor(xSobelActor);xSobelRender->ResetCamera();xSobelRender->SetBackground(0, 1, 0);vtkSmartPointer<vtkRenderer> ySobelRender =vtkSmartPointer<vtkRenderer>::New();ySobelRender->SetViewport(ySobelView);ySobelRender->AddActor(ySobelActor);ySobelRender->ResetCamera();ySobelRender->SetBackground(0, 0, 1);//vtkSmartPointer<vtkRenderWindow> rw =vtkSmartPointer<vtkRenderWindow>::New();rw->AddRenderer(origRender);rw->AddRenderer(xSobelRender);rw->AddRenderer(ySobelRender);rw->SetSize(960, 320);rw->SetWindowName("Edge by Soebl");vtkSmartPointer<vtkRenderWindowInteractor> rwi =vtkSmartPointer<vtkRenderWindowInteractor>::New();vtkSmartPointer<vtkInteractorStyleImage> style =vtkSmartPointer<vtkInteractorStyleImage>::New();rwi->SetInteractorStyle(style);rwi->SetRenderWindow(rw);rwi->Initialize();rwi->Start();return 0; }
該例中計算利用Sobel算子計算圖像的梯度圖像,然后提取X方向的梯度分量和Y方向的梯度分量。 由于計算Sobel算子的值可能存在負值,因此利用vtkImageMathematics對各個分量圖像計算絕對值,再由vtkImageShiftScale將圖像的數值范圍調節到0-255之間再顯示。 執行結果如下:

2.參看資料

1.《C++ primer》
2.《The VTK User’s Guide – 11thEdition》
3.《The Visualization Toolkit – AnObject-Oriented Approach To 3D Graphics (4th Edition)》
4. ?張曉東, 羅火靈. VTK圖形圖像開發進階[M]. 機械工業出版社, 2015.

總結

以上是生活随笔為你收集整理的VTK修炼之道33:边缘检测_Sobel算子的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: yy4138理论片动漫理论片 | 好男人www社区 | 少妇15p| 久久婷香 | 欧美女人一区二区 | 日韩喷潮| 69久久夜色精品国产69 | 自拍偷拍亚洲图片 | 极品超粉嫩尤物69xx | 国产精品一二三区在线观看 | 久久午夜电影 | 97精品久久人人爽人人爽 | 99久久香蕉 | 成人午夜网站 | 日本免费黄色网址 | 超碰h| 中文精品久久 | 麻豆videos| 免费高清欧美大片在线观看 | 中文字幕在线观看网址 | 欧美精品一级 | 亚洲高潮无码久久 | 欧美一区二区三区在线 | 亚洲三级免费 | 青青草免费在线观看视频 | 烈性摔跤 | 亚洲精品资源在线 | 美国一级大黄一片免费中文 | 欧美性爱精品在线 | 黄色wwww | 人人草在线视频 | 性欧美17一18内谢 | 久99视频| 国产另类精品 | 黄色1级视频 | 蜜桃视频在线观看污 | 粗大的内捧猛烈进出在线视频 | 成年人在线免费看 | 成色网 | 免费福利小视频 | 69网站在线观看 | 337p粉嫩大胆色噜噜狠狠图片 | 久久精品三级 | 久久精品欧美一区二区 | 五月天激情综合 | 色欧美视频 | 污视频网站免费在线观看 | 成人高潮片| 国产精品一区网站 | 国产精品无码白浆高潮 | 美女自拍视频 | 国产91清纯白嫩初高中在线观看 | 久久99精品久久久久 | 精品动漫一区二区三区在线观看 | 国产亚洲色婷婷久久 | 欧美自拍在线 | 日韩欧美成人一区二区三区 | 国产精品美女av | 久久久久人妻一区精品色欧美 | 亚洲三级黄色 | 午夜免费影院 | 国产一级特黄a高潮片 | 五月综合久久 | 在线观看av资源 | 欧美一级特黄aaaaaa | 人妻丝袜一区 | 欧美成人黄色网 | 丁香婷婷久久 | av高清| 日本高清免费不卡视频 | 三级网站在线免费观看 | 亚洲电影影音先锋 | 国产在线播放一区 | 在线中文字幕一区 | 久久久一级 | 午夜宅男网 | 日韩欧美一级大片 | 日韩精品成人 | 欧美男女激情 | 可以免费在线观看的av | 日韩网站在线播放 | 国产一级做a爰片久久毛片男 | 超碰在线人人干 | 中文字幕 国产精品 | 美女扒开下面让男人捅 | missav | 免费高清av在线看 | 国产精品成久久久久三级 | 色婷婷狠| 91精品婷婷国产综合久久蝌蚪 | 一级黄色片网址 | sese亚洲| 51热门大瓜今日大瓜 | 欧美67194 | 欧美大浪妇猛交饥渴大叫 | 超碰美女在线 | 中文字幕线人 | 老色批影院 | 欧美久久一区二区三区 | 一区二区欧美日韩 |