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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

VTK修炼之道16:图像处理_窗口分割和图像融合(ViewportvtkImageBlend)

發布時間:2025/3/15 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 VTK修炼之道16:图像处理_窗口分割和图像融合(ViewportvtkImageBlend) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.前言

前面演示的例子都是在一個窗口中顯示一個圖像。但是在常見的圖像處理軟件中,經常會遇到在一個窗口中顯示多個圖像,這就會用到圖像融合技術。圖像融合利用圖像的alpha通道和不透明度來實現。VTK中vtkImageBlend實現圖像的融合。

vtkImageBlend可以接收多個圖像輸入,輸出為融合圖像。輸出圖像的像素間隔、原點、范圍(extent)以及像素組分個數與第一個圖像一致。該類提供了兩種融合模式,默認的融合方式是標準模式

第二種是混合模式(Compound)。該模式下輸出結果經過alpha/opacity不透明度的和做過歸一化。另外還可以設置一個閾值,當alpha*opacity小于等于該閾值時會忽略該像素。

2.實驗代碼和結果

#include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL);#include <vtkSmartPointer.h> #include <vtkJPEGReader.h> //#include <vtkImageCast.h> #include <vtkImageData.h> #include <vtkImageCanvasSource2D.h> #include <vtkImageBlend.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("data/lena-gray.jpg");reader->Update();vtkSmartPointer<vtkImageCanvasSource2D> source=vtkSmartPointer<vtkImageCanvasSource2D>::New();source->SetNumberOfScalarComponents(1);source->SetScalarTypeToUnsignedChar();source->SetExtent(0,512,0,512,0,0);source->SetDrawColor(0,0,0);source->FillBox(0,512,0,512);source->SetDrawColor(255,255,255);source->FillBox(100,400,100,400);source->Update();vtkSmartPointer<vtkImageBlend> blend =vtkSmartPointer<vtkImageBlend>::New();blend->SetInputData(0,reader->GetOutput());blend->SetInputData(1,source->GetOutput());blend->SetOpacity(0,0.4);blend->SetOpacity(1,0.6);blend->Update();//渲染引擎vtkSmartPointer<vtkImageActor> actor1 =vtkSmartPointer<vtkImageActor>::New();actor1->SetInputData(reader->GetOutput());vtkSmartPointer<vtkImageActor> actor2 =vtkSmartPointer<vtkImageActor>::New();actor2->SetInputData(source->GetOutput());vtkSmartPointer<vtkImageActor> blend_actor =vtkSmartPointer<vtkImageActor>::New();blend_actor->SetInputData(blend->GetOutput());//定義視窗大小(xmin.ymin,xmax,ymax)//按window的尺寸進行比例分割double leftViewport [4] = {0,0,0.33,1};double midViewport [4] = {0.33,0,0.66,1};double rightViewport[4] = {0.66,0,1,1};//rendervtkSmartPointer<vtkRenderer> render1 = vtkSmartPointer<vtkRenderer>::New();render1->SetViewport(leftViewport);render1->AddActor(actor1);render1->ResetCamera();render1->SetBackground(1,0,0);vtkSmartPointer<vtkRenderer> render2 = vtkSmartPointer<vtkRenderer>::New();render2->SetViewport(midViewport);render2->AddActor(actor2);render2->ResetCamera();render2->SetBackground(0,1,0);vtkSmartPointer<vtkRenderer> render3 = vtkSmartPointer<vtkRenderer>::New();render3->SetViewport(rightViewport);render3->AddActor(blend_actor);render3->ResetCamera();render3->SetBackground(0,0,1);//windowvtkSmartPointer<vtkRenderWindow> renderwindow =vtkSmartPointer<vtkRenderWindow>::New();renderwindow->AddRenderer(render1);renderwindow->AddRenderer(render2);renderwindow->AddRenderer(render3);renderwindow->SetSize(640,320);renderwindow->SetWindowName("Image-Fusion");renderwindow->Render();//interactorvtkSmartPointer<vtkRenderWindowInteractor> rwi =vtkSmartPointer<vtkRenderWindowInteractor>::New();vtkSmartPointer<vtkInteractorStyleImage> style =vtkSmartPointer<vtkInteractorStyleImage>::New();rwi->SetInteractorStyle(style);rwi->SetRenderWindow(renderwindow);rwi->Initialize();rwi->Start();return 0; }代碼中讀入了一副灰度圖像,并生成了一個二值圖像;然后定義了vtkImageBlend對象,函數SetInput()設置兩個圖像作為輸入。這里設置輸入圖像時,由于可以輸入多個圖像,因此需要給定圖像的id號來設置輸入。SetOpacity()用于設置對應id號的圖像不透明度的大小,當不透明度為1.0時,為完全不透明。


3.參考資料

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.

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的VTK修炼之道16:图像处理_窗口分割和图像融合(ViewportvtkImageBlend)的全部內容,希望文章能夠幫你解決所遇到的問題。

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