/*========================================================================= Program: Visualization Toolkit Module: TestImageSliceMapperOrient3D.cxx Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen All rights reserved. See Copyright.txt or http://www.kitware.com/Copyright.htm for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ // This tests 3D images that are not in the XY plane. // // The command line arguments are: // -I => run in interactive mode #include "vtkCamera.h" #include "vtkImageData.h" #include "vtkImageProperty.h" #include "vtkImageReader2.h" #include "vtkImageSlice.h" #include "vtkImageSliceMapper.h" #include "vtkInteractorStyleImage.h" #include "vtkMatrix3x3.h" #include "vtkNew.h" #include "vtkRegressionTestImage.h" #include "vtkRenderWindow.h" #include "vtkRenderWindowInteractor.h" #include "vtkRenderer.h" #include "vtkTestUtilities.h" #include "vtkTransform.h" int TestImageSliceMapperOriented3D(int argc, char* argv[]) { vtkNew iren; vtkNew style; vtkNew renWin; iren->SetRenderWindow(renWin); iren->SetInteractorStyle(style); vtkNew reader; reader->SetDataByteOrderToLittleEndian(); reader->SetDataExtent(0, 63, 0, 63, 1, 93); reader->SetDataSpacing(3.2, 3.2, 1.5); // a nice random-ish origin for testing reader->SetDataOrigin(2.5, -13.6, 2.8); // compute a direction matrix for testing double mat4[16]; vtkNew trans; trans->RotateY(20); trans->RotateX(20); vtkMatrix4x4::DeepCopy(mat4, trans->GetMatrix()->GetData()); double dir[9] = { mat4[0], mat4[1], mat4[2], mat4[4], mat4[5], mat4[6], mat4[8], mat4[9], mat4[10] }; reader->SetDataDirection(dir); char* fname = vtkTestUtilities::ExpandDataFileName(argc, argv, "Data/headsq/quarter"); reader->SetFilePrefix(fname); reader->Update(); delete[] fname; for (int i = 0; i < 4; i++) { vtkNew renderer; vtkCamera* camera = renderer->GetActiveCamera(); renderer->SetBackground(0.1, 0.2, 0.4); renderer->SetViewport(0.5 * (i & 1), 0.25 * (i & 2), 0.5 + 0.5 * (i & 1), 0.5 + 0.25 * (i & 2)); renWin->AddRenderer(renderer); vtkNew imageMapper; imageMapper->SetInputConnection(reader->GetOutputPort()); imageMapper->SliceAtFocalPointOn(); const double* bounds = imageMapper->GetBounds(); double point[3]; point[0] = 0.5 * (bounds[0] + bounds[1]); point[1] = 0.5 * (bounds[2] + bounds[3]); point[2] = 0.5 * (bounds[4] + bounds[5]); if (i < 3) { imageMapper->SetOrientation(i); } camera->SetFocalPoint(point); point[imageMapper->GetOrientation()] += 500.0; camera->SetPosition(point); camera->ParallelProjectionOn(); camera->SetParallelScale(120.0); if (imageMapper->GetOrientation() != 2) { camera->SetViewUp(0.0, 0.0, -1.0); } if (i == 3) { camera->Azimuth(20); camera->Elevation(-20); } vtkNew image; image->SetMapper(imageMapper); renderer->AddViewProp(image); image->GetProperty()->SetColorWindow(2000); image->GetProperty()->SetColorLevel(1000); } renWin->SetSize(400, 400); renWin->Render(); int retVal = vtkRegressionTestImage(renWin); if (retVal == vtkRegressionTester::DO_INTERACTOR) { iren->Start(); } return !retVal; }