VTK 实例25:BMP图像像素值的访问与修改

发布时间 2023-08-15 11:29:17作者: 一杯清酒邀明月
 1 #include "vtkAutoInit.h" 
 2 VTK_MODULE_INIT(vtkRenderingOpenGL2);
 3 VTK_MODULE_INIT(vtkInteractionStyle);
 4 #include <vtkSmartPointer.h>
 5 #include <vtkImageViewer2.h>
 6 #include <vtkRenderWindow.h>
 7 #include <vtkRenderWindowInteractor.h>
 8 #include <vtkRenderer.h>
 9 #include <vtkBMPReader.h>
10 #include <vtkImageData.h>
11 #include <vtkImageIterator.h>
12 
13 //测试图像:../data/lena.bmp
14 int main(int argc, char* argv[])
15 {
16     vtkSmartPointer<vtkBMPReader> reader =
17     vtkSmartPointer<vtkBMPReader>::New();
18     reader->SetFileName ( "lena.bmp" );
19     reader->Update();
20 
21     int subRegion[6] = {0,300, 0, 300, 0, 0};
22     vtkImageIterator<unsigned char> it(reader->GetOutput(), subRegion);
23 
24     while(!it.IsAtEnd())
25     {
26         unsigned char *inSI = it.BeginSpan();
27         unsigned char *inSIEnd = it.EndSpan();
28 
29         while(inSI != inSIEnd)
30         {
31             *inSI = 255-*inSI;
32             ++inSI;
33         }
34         it.NextSpan();
35     }
36 
37     vtkSmartPointer<vtkImageViewer2> imageViewer =
38         vtkSmartPointer<vtkImageViewer2>::New();
39     imageViewer->SetInputConnection(reader->GetOutputPort());
40 
41     vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor =
42         vtkSmartPointer<vtkRenderWindowInteractor>::New();
43     imageViewer->SetupInteractor(renderWindowInteractor);
44     imageViewer->Render();
45     imageViewer->GetRenderer()->ResetCamera();
46     imageViewer->Render();
47 
48     imageViewer->GetRenderer()->SetBackground(1.0, 1.0, 1.0);
49     imageViewer->SetSize(640, 480);
50     imageViewer->GetRenderWindow()->SetWindowName("VisitImagePixelIterativelyExample");
51 
52     renderWindowInteractor->Start();
53 
54     return 0;
55 }