一杯清酒邀明月
天下本无事,庸人扰之而烦耳。
posts - 3121,comments - 209,views - 580万
复制代码
 1 #include "vtkAutoInit.h" 
 2 VTK_MODULE_INIT(vtkRenderingOpenGL2);
 3 VTK_MODULE_INIT(vtkInteractionStyle);
 4 
 5 #include <vtkMath.h>
 6 #include <vtkSmartPointer.h>
 7 #include <vtkImageCanvasSource2D.h>
 8 #include <vtkImageMathematics.h>
 9 #include <vtkRenderWindow.h>
10 #include <vtkRenderWindowInteractor.h>
11 #include <vtkInteractorStyleImage.h>
12 #include <vtkRenderer.h>
13 #include <vtkImageActor.h>
14 
15 int main(int, char *[])
16 {
17     vtkSmartPointer<vtkImageCanvasSource2D> imageSource = 
18         vtkSmartPointer<vtkImageCanvasSource2D>::New();
19     imageSource->SetNumberOfScalarComponents(3);
20     imageSource->SetScalarTypeToUnsignedChar();
21     imageSource->SetExtent(0, 4, 0, 4, 0, 0);
22     imageSource->SetDrawColor(100.0, 0, 0);
23     imageSource->FillBox(0, 4, 0, 4);
24     imageSource->Update();
25 
26     vtkSmartPointer<vtkImageMathematics> imageMath = 
27         vtkSmartPointer<vtkImageMathematics>::New();
28     imageMath->SetOperationToMultiplyByK();
29     imageMath->SetConstantK(2.0);
30     imageMath->SetInputConnection(imageSource->GetOutputPort());
31     imageMath->Update();
32 
33     vtkSmartPointer<vtkImageActor> originalActor =
34         vtkSmartPointer<vtkImageActor>::New();
35     originalActor->SetInputData(imageSource->GetOutput());
36 
37     vtkSmartPointer<vtkImageActor> mathActor =
38         vtkSmartPointer<vtkImageActor>::New();
39     mathActor->SetInputData(imageMath->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<vtkRenderer> originalRenderer =
45         vtkSmartPointer<vtkRenderer>::New();
46     originalRenderer->SetViewport(leftViewport);
47     originalRenderer->AddActor(originalActor);
48     originalRenderer->ResetCamera();
49     originalRenderer->SetBackground(1.0, 1.0, 1.0);
50 
51     vtkSmartPointer<vtkRenderer> gradientMagnitudeRenderer =
52         vtkSmartPointer<vtkRenderer>::New();
53     gradientMagnitudeRenderer->SetViewport(rightViewport);
54     gradientMagnitudeRenderer->AddActor(mathActor);
55     gradientMagnitudeRenderer->ResetCamera();
56     gradientMagnitudeRenderer->SetBackground(1.0, 1.0, 1.0);
57 
58     vtkSmartPointer<vtkRenderWindow> renderWindow =
59         vtkSmartPointer<vtkRenderWindow>::New();
60     renderWindow->AddRenderer(originalRenderer);
61     renderWindow->AddRenderer(gradientMagnitudeRenderer);
62     renderWindow->SetSize(640, 480);
63     renderWindow->Render();
64     renderWindow->SetWindowName("ImageMathematicsExample");
65 
66     vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor =
67         vtkSmartPointer<vtkRenderWindowInteractor>::New();
68     vtkSmartPointer<vtkInteractorStyleImage> style =
69         vtkSmartPointer<vtkInteractorStyleImage>::New();
70 
71     renderWindowInteractor->SetInteractorStyle(style);
72     renderWindowInteractor->SetRenderWindow(renderWindow);
73     renderWindowInteractor->Initialize();
74     renderWindowInteractor->Start();
75 
76     return EXIT_SUCCESS;
77 }
复制代码

posted on   一杯清酒邀明月  阅读(42)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
历史上的今天:
2022-08-15 Qt item setZValue() 函数
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示