首页 > 其他分享 >VTK 实例37:梯度算子(边缘检测)

VTK 实例37:梯度算子(边缘检测)

时间:2023-08-15 11:58:24浏览次数:48  
标签:ShiftScale 1.0 VTK 37 vtkSmartPointer 算子 renderWindow New include

 1 #include "vtkAutoInit.h" 
 2 VTK_MODULE_INIT(vtkRenderingOpenGL2);
 3 VTK_MODULE_INIT(vtkInteractionStyle);
 4 
 5 #include <vtkSmartPointer.h>
 6 #include <vtkImageData.h>
 7 #include <vtkRenderWindow.h>
 8 #include <vtkRenderWindowInteractor.h>
 9 #include <vtkInteractorStyleImage.h>
10 #include <vtkRenderer.h>
11 #include <vtkImageActor.h>
12 #include <vtkJPEGReader.h>
13 #include <vtkImageGradient.h>
14 #include <vtkImageMagnitude.h>
15 #include <vtkImageCast.h>
16 #include <vtkImageShiftScale.h>
17 
18 //测试图像:../data/lena-gray.jpg
19 int main(int argc, char* argv[])
20 {
21     vtkSmartPointer<vtkJPEGReader> reader =
22         vtkSmartPointer<vtkJPEGReader>::New();
23     reader->SetFileName("lena-gray.jpg");
24     reader->Update();
25 
26     vtkSmartPointer<vtkImageGradient> gradientFilter =
27         vtkSmartPointer<vtkImageGradient>::New();
28     gradientFilter->SetInputConnection(reader->GetOutputPort());
29     gradientFilter->SetDimensionality(2);
30 
31     vtkSmartPointer<vtkImageMagnitude> magnitudeFilter =
32         vtkSmartPointer<vtkImageMagnitude>::New();
33     magnitudeFilter->SetInputConnection(gradientFilter->GetOutputPort());
34     magnitudeFilter->Update();
35 
36     double range[2];
37     magnitudeFilter->GetOutput()->GetScalarRange(range);
38 
39     vtkSmartPointer<vtkImageShiftScale> ShiftScale =
40         vtkSmartPointer<vtkImageShiftScale>::New();
41     ShiftScale->SetOutputScalarTypeToUnsignedChar();
42     ShiftScale->SetScale( 255 / range[1] );
43     ShiftScale->SetInputConnection(magnitudeFilter->GetOutputPort());
44     ShiftScale->Update();
45 
46     vtkSmartPointer<vtkImageActor> originalActor =
47         vtkSmartPointer<vtkImageActor>::New();
48     originalActor->SetInputData(reader->GetOutput());
49 
50     vtkSmartPointer<vtkImageActor> gradActor =
51         vtkSmartPointer<vtkImageActor>::New();
52     gradActor->SetInputData(ShiftScale->GetOutput());
53 
54     double originalViewport[4] = {0.0, 0.0, 0.5, 1.0};
55     double gradviewport[4] = {0.5, 0.0, 1.0, 1.0};
56 
57     vtkSmartPointer<vtkRenderer> originalRenderer =
58         vtkSmartPointer<vtkRenderer>::New();
59     originalRenderer->SetViewport(originalViewport);
60     originalRenderer->AddActor(originalActor);
61     originalRenderer->ResetCamera();
62     originalRenderer->SetBackground(1.0, 1.0, 1.0);
63 
64     vtkSmartPointer<vtkRenderer> gradRenderer =
65         vtkSmartPointer<vtkRenderer>::New();
66     gradRenderer->SetViewport(gradviewport);
67     gradRenderer->AddActor(gradActor);
68     gradRenderer->ResetCamera();
69     gradRenderer->SetBackground(1.0, 1.0, 1.0);
70 
71     vtkSmartPointer<vtkRenderWindow> renderWindow =
72         vtkSmartPointer<vtkRenderWindow>::New();
73     renderWindow->AddRenderer(originalRenderer);
74     renderWindow->AddRenderer(gradRenderer);
75     renderWindow->SetSize( 640, 320 );
76     renderWindow->Render();
77     renderWindow->SetWindowName("ImageGradientExample");
78 
79     vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor =
80         vtkSmartPointer<vtkRenderWindowInteractor>::New();
81     vtkSmartPointer<vtkInteractorStyleImage> style =
82         vtkSmartPointer<vtkInteractorStyleImage>::New();
83 
84     renderWindowInteractor->SetInteractorStyle(style);
85     renderWindowInteractor->SetRenderWindow(renderWindow);
86     renderWindowInteractor->Initialize();
87     renderWindowInteractor->Start();
88 
89     return EXIT_SUCCESS;
90 }

标签:ShiftScale,1.0,VTK,37,vtkSmartPointer,算子,renderWindow,New,include
From: https://www.cnblogs.com/ybqjymy/p/17630958.html

相关文章

  • VTK 实例38:Sobel梯度算子(边缘检测)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageMathematics.h>7#include<vtkImageData.h>8#inc......
  • VTK 实例39:拉普拉斯算子(边缘检测)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkImageCanvasSource2D.h>8#include......
  • VTK 实例40:均值滤波(图像光滑)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkImageConvolve.h>8#include<vt......
  • VTK 实例31:灰度图像直方图
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkActor.h>6#include<vtkBarChartActor.h>7#include<vtkFieldData.h>8#include<v......
  • VTK 实例32:图像重采样(降采样)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkImageShiftScale.h>8#include<......
  • 酷睿i7 13650hx和13700h 差距 i713650hx和13700h对比
    i713650hx采用10nm工艺最高睿频4.9GHz十四核心二十线程三级缓存24MB热设计功耗(TDP)55W支持最大内存128GB内存类型DDR43200MHzDDR54800MHz集成显卡IntelUHDGraphics笔记本cpu选i713650hx还是i713700h这些点很重要看过你就懂了 http://www.adiannao.cn/dyi7......
  • 评测 i7 13700hx和i9 13900h差距 酷睿i713700hx和i913900h对比
    i913900h采用10纳米制作工艺最高睿频5.4GHz十四核心二十线程三级缓存36MB热设计功耗(TDP)115W支持最大内存64GB内存类型DDR43200MHzDDR55200MHz集成显卡IntelIrisXeGraphics选i713700hx还是i913900H这些点很重要看过你就懂了 http://www.adiannao.cn/dyi71......
  • VTK 实例33:图像重采样(降和升采样)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkRenderWindow.h>8#include......
  • i7 13700HX和 r7 7840HS差距 酷睿i713700HX和 锐龙r77840HS对比
    锐龙77840HS,其采用最新的Zen4架构,工艺也升级到了最新的台积电4nm。8核心16线程,40MB的缓存,基础频率3.8GHz,最高频率可以达到5.1GHz。GPU搭载全新的Radeon780M选i713700HX还是r77840HS这些点很重要 http://www.adiannao.cn/dyi713700hx采用10nm工艺16个核和24......
  • VTK 实例26:将BMP类型的RGB图像转换为灰度图像
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkRenderWindow.h>8#include<vtk......