首页 > 其他分享 >VTK 实例43:各向异性滤波(图像光滑)

VTK 实例43:各向异性滤波(图像光滑)

时间:2023-08-15 12:29:54浏览次数:42  
标签:1.0 VTK 滤波 43 vtkSmartPointer renderWindow New include leftRenderer

 1 #include "vtkAutoInit.h" 
 2 VTK_MODULE_INIT(vtkRenderingOpenGL2);
 3 VTK_MODULE_INIT(vtkInteractionStyle);
 4 
 5 #include <vtkSmartPointer.h>
 6 #include <vtkCamera.h>
 7 #include <vtkImageActor.h>
 8 #include <vtkImageAnisotropicDiffusion2D.h>
 9 #include <vtkImageAnisotropicDiffusion3D.h>
10 #include <vtkImageCast.h>
11 #include <vtkImageData.h>
12 #include <vtkImageMandelbrotSource.h>
13 #include <vtkInteractorStyleImage.h>
14 #include <vtkJPEGReader.h>
15 #include <vtkRenderWindow.h>
16 #include <vtkRenderWindowInteractor.h>
17 #include <vtkRenderer.h>
18 
19 //测试图像:../data/lena-gray.jpg
20 int main(int argc, char* argv[])
21 {
22     vtkSmartPointer<vtkJPEGReader> reader =
23         vtkSmartPointer<vtkJPEGReader>::New();
24     reader->SetFileName("lena-gray.jpg");
25 
26     vtkSmartPointer<vtkImageAnisotropicDiffusion2D> diffusion =
27         vtkSmartPointer<vtkImageAnisotropicDiffusion2D>::New();
28     diffusion->SetInputConnection(reader->GetOutputPort());
29     diffusion->SetNumberOfIterations(10);
30     diffusion->SetDiffusionThreshold(20);
31     diffusion->Update();
32 
33     vtkSmartPointer<vtkImageActor> originalActor =
34         vtkSmartPointer<vtkImageActor>::New();
35     originalActor->SetInputData(reader->GetOutput());
36 
37     vtkSmartPointer<vtkImageActor> diffusionActor =
38         vtkSmartPointer<vtkImageActor>::New();
39     diffusionActor->SetInputData(diffusion->GetOutput());
40 
41     double leftViewport[4] = {0.0, 0.0, 0.5, 1.0};
42     double rightViewport[4] = {0.5, 0.0, 1.0, 1.0};
43 
44     vtkSmartPointer<vtkCamera> camera =
45         vtkSmartPointer<vtkCamera>::New();
46     vtkSmartPointer<vtkRenderer> leftRenderer =
47         vtkSmartPointer<vtkRenderer>::New();
48     leftRenderer->SetViewport(leftViewport);
49     leftRenderer->AddActor(originalActor);
50     leftRenderer->SetBackground(1.0, 1.0, 1.0);
51     leftRenderer->SetActiveCamera(camera);
52     leftRenderer->ResetCamera();
53 
54     vtkSmartPointer<vtkRenderer> rightRenderer =
55         vtkSmartPointer<vtkRenderer>::New();
56     rightRenderer->SetViewport(rightViewport);
57     rightRenderer->SetBackground(1.0, 1.0, 1.0);
58     rightRenderer->AddActor(diffusionActor);
59     rightRenderer->SetActiveCamera(camera);
60 
61     vtkSmartPointer<vtkRenderWindow> renderWindow =
62         vtkSmartPointer<vtkRenderWindow>::New();
63     renderWindow->AddRenderer(leftRenderer);
64     renderWindow->AddRenderer(rightRenderer);
65     renderWindow->SetSize(640, 320);
66     renderWindow->Render();
67     renderWindow->SetWindowName("AnistropicFilteringExample");
68 
69     vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor =
70         vtkSmartPointer<vtkRenderWindowInteractor>::New();
71     vtkSmartPointer<vtkInteractorStyleImage> style =
72         vtkSmartPointer<vtkInteractorStyleImage>::New();
73 
74     renderWindowInteractor->SetInteractorStyle(style);
75     renderWindowInteractor->SetRenderWindow(renderWindow);
76     renderWindowInteractor->Initialize();
77     renderWindowInteractor->Start();
78 
79     return EXIT_SUCCESS;
80 }

标签:1.0,VTK,滤波,43,vtkSmartPointer,renderWindow,New,include,leftRenderer
From: https://www.cnblogs.com/ybqjymy/p/17631002.html

相关文章

  • VTK 实例44:二维图像快速傅里叶变换(频域处理)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkImageData.h>7#include<vtkImageFFT.h>8#include<......
  • VTK 实例35:图像运算(逻辑运算)
    1#include"vtkAutoInit.h"2VTK_MODULE_INIT(vtkRenderingOpenGL2);3VTK_MODULE_INIT(vtkInteractionStyle);45#include<vtkSmartPointer.h>6#include<vtkMath.h>7#include<vtkImageData.h>8#include<vtk......
  • VTK 实例36:图像二值化
    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......
  • VTK 实例37:梯度算子(边缘检测)
    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......
  • 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<......
  • 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......