一杯清酒邀明月
天下本无事,庸人扰之而烦耳。
posts - 3121,comments - 209,views - 578万

1.彩色图像RGB成分提取

VTK中利用vtkImageExtractComponents可以方便的提取出彩色图像的各个颜色分量,该类的使用比较简单,只需要设置要提取的分量序号即可。下面代码说明了怎样提取彩色图像的某个颜色分量。
复制代码
  1 #include <vtkAutoInit.h>
  2 VTK_MODULE_INIT(vtkRenderingOpenGL);
  3  
  4 #include <vtkSmartPointer.h>
  5 #include <vtkBMPReader.h>
  6 #include <vtkImageExtractComponents.h>
  7 #include <vtkImageActor.h>
  8 #include <vtkRenderer.h>
  9 #include <vtkRenderWindow.h>
 10 #include <vtkRenderWindowInteractor.h>
 11 #include <vtkInteractorStyleImage.h>
 12  
 13 int main()
 14 {
 15     vtkSmartPointer<vtkBMPReader> reader =
 16         vtkSmartPointer<vtkBMPReader>::New();
 17     reader->SetFileName("lena.bmp");
 18  
 19     vtkSmartPointer<vtkImageExtractComponents> redComponent =
 20         vtkSmartPointer<vtkImageExtractComponents>::New();
 21     redComponent->SetInputConnection(reader->GetOutputPort());
 22     redComponent->SetComponents(0);
 23     redComponent->Update();
 24  
 25     vtkSmartPointer<vtkImageExtractComponents> greenComponent =
 26         vtkSmartPointer<vtkImageExtractComponents>::New();
 27     greenComponent->SetInputConnection(reader->GetOutputPort());
 28     greenComponent->SetComponents(1);
 29     greenComponent->Update();
 30  
 31     vtkSmartPointer<vtkImageExtractComponents> blueComponent =
 32         vtkSmartPointer<vtkImageExtractComponents>::New();
 33     blueComponent->SetInputConnection(reader->GetOutputPort());
 34     blueComponent->SetComponents(2);
 35     blueComponent->Update();
 36     //创建演员
 37     vtkSmartPointer<vtkImageActor> origActor =
 38         vtkSmartPointer<vtkImageActor>::New();
 39     origActor->SetInputData(reader->GetOutput());
 40  
 41     vtkSmartPointer<vtkImageActor> redActor =
 42         vtkSmartPointer<vtkImageActor>::New();
 43     redActor->SetInputData(redComponent->GetOutput());
 44  
 45     vtkSmartPointer<vtkImageActor> greenActor =
 46         vtkSmartPointer<vtkImageActor>::New();
 47     greenActor->SetInputData(greenComponent->GetOutput());
 48  
 49     vtkSmartPointer<vtkImageActor> blueActor =
 50         vtkSmartPointer<vtkImageActor>::New();
 51     blueActor->SetInputData(blueComponent->GetOutput());
 52     //定义窗口 并化妆
 53     double origView[4] = { 0.0, 0.0, 0.25, 1.0 };
 54     double redView[4] = { 0.25, 0.0, 0.5, 1.0 };
 55     double greenView[4] = { 0.5, 0.0, 0.75, 1.0 };
 56     double blueView[4] = { 0.75, 0.0, 1.0, 1.0 };
 57  
 58     vtkSmartPointer<vtkRenderer> origRender =
 59         vtkSmartPointer<vtkRenderer>::New();
 60     origRender->SetViewport(origView);
 61     origRender->AddActor(origActor);
 62     origRender->ResetCamera();
 63     origRender->SetBackground(1.0, 1.0, 1.0);
 64  
 65     vtkSmartPointer<vtkRenderer> redRender =
 66         vtkSmartPointer<vtkRenderer>::New();
 67     redRender->SetViewport(redView);
 68     redRender->AddActor(redActor);
 69     redRender->ResetCamera();
 70     redRender->SetBackground(1.0, 1.0, 1.0);
 71  
 72     vtkSmartPointer<vtkRenderer> greenRender =
 73         vtkSmartPointer<vtkRenderer>::New();
 74     greenRender->SetViewport(greenView);
 75     greenRender->AddActor(greenActor);
 76     greenRender->ResetCamera();
 77     greenRender->SetBackground(1.0, 1.0, 1.0);
 78  
 79     vtkSmartPointer<vtkRenderer> blueRender =
 80         vtkSmartPointer<vtkRenderer>::New();
 81     blueRender->SetViewport(blueView);
 82     blueRender->AddActor(blueActor);
 83     blueRender->ResetCamera();
 84     blueRender->SetBackground(1.0, 1.0, 1.0);
 85     //上舞台
 86     vtkSmartPointer<vtkRenderWindow> renderwindow =
 87         vtkSmartPointer<vtkRenderWindow>::New();
 88     renderwindow->AddRenderer(origRender);
 89     renderwindow->AddRenderer(redRender);
 90     renderwindow->AddRenderer(greenRender);
 91     renderwindow->AddRenderer(blueRender);
 92     renderwindow->SetSize(960, 320);
 93     renderwindow->Render();
 94     renderwindow->SetWindowName("ExtraImageColorComponents");
 95     //设置交互
 96     vtkSmartPointer<vtkRenderWindowInteractor> rwi =
 97         vtkSmartPointer<vtkRenderWindowInteractor>::New();
 98     vtkSmartPointer<vtkInteractorStyleImage> style =
 99         vtkSmartPointer<vtkInteractorStyleImage>::New();
100     rwi->SetInteractorStyle(style);
101     rwi->SetRenderWindow(renderwindow);
102     rwi->Initialize();
103  
104     rwi->Start(); 
105     return 0;
106 }
复制代码

 

 

posted on   一杯清酒邀明月  阅读(263)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
历史上的今天:
2020-01-06 VisionPro 图标工具说明
2020-01-06 Qt OpenCV::Mat与Qt::QImage相互转换
2020-01-06 QT .和::和:和->
2020-01-06 Qt QImage的浅拷贝与深拷贝
2020-01-06 Qt QImag图像保存、格式转换
2020-01-06 Qt 获取当前时间
2020-01-06 Qt 信号阻塞和断开
< 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

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