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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
// SPDX-License-Identifier: BSD-3-Clause
// .NAME Test of vtkBMPReader
// .SECTION Description
//
#include "vtkSmartPointer.h"
#include "vtkBMPReader.h"
#include "vtkImageData.h"
#include "vtkImageViewer2.h"
#include "vtkLookupTable.h"
#include "vtkRenderWindowInteractor.h"
#include "vtkRenderer.h"
int TestBMPReaderDoNotAllow8BitBMP(int argc, char* argv[])
{
if (argc <= 1)
{
cout << "Usage: " << argv[0] << " <bmp file>" << endl;
return EXIT_FAILURE;
}
std::string filename = argv[1];
vtkSmartPointer<vtkBMPReader> BMPReader = vtkSmartPointer<vtkBMPReader>::New();
// Check the image can be read
if (!BMPReader->CanReadFile(filename.c_str()))
{
cerr << "CanReadFile failed for " << filename << "\n";
return EXIT_FAILURE;
}
// Read the input image
BMPReader->SetFileName(filename.c_str());
BMPReader->Update();
// Read and display the image properties
int depth = BMPReader->GetDepth();
cout << "depth: " << depth << endl;
const char* fileExtensions = BMPReader->GetFileExtensions();
cout << "fileExtensions: " << fileExtensions << endl;
const char* descriptiveName = BMPReader->GetDescriptiveName();
cout << "descriptiveName: " << *descriptiveName << endl;
vtkSmartPointer<vtkLookupTable> lookupTable = BMPReader->GetLookupTable();
lookupTable->Print(cout);
const unsigned char* colors = BMPReader->GetColors();
unsigned char const* first = reinterpret_cast<unsigned char*>(&colors);
unsigned char const* last = reinterpret_cast<unsigned char*>(&colors + 1);
cout << "colors: ";
while (first != last)
{
cout << (int)*first << ' ';
++first;
}
cout << std::endl;
int allow8BitBMP = 0;
BMPReader->SetAllow8BitBMP(allow8BitBMP);
cout << "allow8BitBMP: " << BMPReader->GetAllow8BitBMP() << endl;
// Visualize
vtkSmartPointer<vtkImageViewer2> imageViewer = vtkSmartPointer<vtkImageViewer2>::New();
imageViewer->SetInputConnection(BMPReader->GetOutputPort());
vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor =
vtkSmartPointer<vtkRenderWindowInteractor>::New();
imageViewer->SetupInteractor(renderWindowInteractor);
imageViewer->Render();
imageViewer->GetRenderer()->ResetCamera();
renderWindowInteractor->Initialize();
imageViewer->Render();
renderWindowInteractor->Start();
return EXIT_SUCCESS;
}
|