Skip to content

MultiBlockVolumeMapper

Repository source: MultiBlockVolumeMapper

Description

This example illustrates using the vtkMultiBlockVolumeMapper to render a vtkMultiBlockDataSet containing eight 10x10x10 volumes.

Other languages

See (PythonicAPI)

Question

If you have a question about this example, please use the VTK Discourse Forum

Code

MultiBlockVolumeMapper.cxx

#include <vtkCamera.h>
#include <vtkColorSeries.h>
#include <vtkImageData.h>
#include <vtkMatrix4x4.h>
#include <vtkMultiBlockDataSet.h>
#include <vtkMultiBlockVolumeMapper.h>
#include <vtkNamedColors.h>
#include <vtkNew.h>
#include <vtkOutlineFilter.h>
#include <vtkPolyDataMapper.h>
#include <vtkProperty.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>
#include <vtkVolumeProperty.h>

int main(int argc, char* argv[])
{
  vtkNew<vtkNamedColors> namedColors;

  // Set up vtkMultiBlockDataSet (just a bunch of colored blocks):
  const int dim[3] = {10, 10, 10};
  double spc[3] = {0.1, 0.1, 0.1};
  vtkNew<vtkMultiBlockDataSet> mb;
  vtkNew<vtkColorSeries> colors;
  colors->SetColorScheme(vtkColorSeries::BREWER_QUALITATIVE_SET3);
  for (int i = 0; i < 8; ++i)
  {
    vtkNew<vtkImageData> img;
    img->SetDimensions(dim);
    img->AllocateScalars(VTK_UNSIGNED_CHAR, 4);
    img->SetSpacing(spc);

    // Position the volumes by their origin:
    // Shift object by the length of a volume in the axis
    //  directions to make them non-overlapping:
    std::array<int, 3> ofs{i % 2, (i / 2) % 2, i / 4};
    img->SetOrigin(ofs[0] * (dim[0] - 1) * spc[0],
                   ofs[1] * (dim[1] - 1) * spc[1],
                   ofs[2] * (dim[2] - 1) * spc[2]);

    // Set colors:
    auto col = colors->GetColor(i);
    for (int x = 0; x < dim[0]; ++x)
    {
      for (int y = 0; y < dim[1]; ++y)
      {
        for (int z = 0; z < dim[2]; ++z)
        {
          for (int c = 0; c < 3; ++c)
          {
            img->SetScalarComponentFromDouble(x, y, z, c, col[c]);
          }
          img->SetScalarComponentFromDouble(x, y, z, 3, 255);
        }
      }
    }
    mb->SetBlock(i, img);
  }

  // Setting up the vtkMultiBlockVolumeMapper:
  vtkNew<vtkMultiBlockVolumeMapper> volMapper;
  volMapper->SetInputDataObject(mb);
  vtkNew<vtkVolume> volume;
  vtkNew<vtkVolumeProperty> volProp;
  volProp->SetIndependentComponents(false);
  volume->SetMapper(volMapper);
  volume->SetProperty(volProp);
  volume->SetVisibility(true);
  // volume->SetOrientation(30, -45, 0);

  // An outline provides context around the data.
  vtkNew<vtkOutlineFilter> outlineData;
  outlineData->SetInputData(mb);

  vtkNew<vtkPolyDataMapper> mapOutline;
  mapOutline->SetInputConnection(outlineData->GetOutputPort());

  vtkNew<vtkActor> outline;
  // outline->SetOrientation(30, -45, 0);
  outline->SetMapper(mapOutline);
  outline->GetProperty()->SetColor(namedColors->GetColor3d("Black").GetData());

  // Standard render window and renderer setup:
  vtkNew<vtkRenderer> renderer;
  renderer->SetBackground(namedColors->GetColor3d("ForestGreen").GetData());
  renderer->AddVolume(volume);
  renderer->AddActor(outline);
  vtkNew<vtkRenderWindow> renWin;
  renWin->SetWindowName("MultiBlockVolumeMapper");
  renWin->AddRenderer(renderer);
  renWin->Render();
  vtkNew<vtkRenderWindowInteractor> iren;
  iren->SetRenderWindow(renWin);

  auto camera = renderer->GetActiveCamera();
  camera->Elevation(30);
  camera->Azimuth(45);
  renderer->ResetCamera();

  iren->Start();

  return EXIT_SUCCESS;
}

CMakeLists.txt

cmake_minimum_required(VERSION 3.12 FATAL_ERROR)

project(MultiBlockVolumeMapper)

find_package(VTK COMPONENTS 
  CommonColor
  CommonCore
  CommonDataModel
  CommonMath
  FiltersModeling
  InteractionStyle
  RenderingContextOpenGL2
  RenderingCore
  RenderingFreeType
  RenderingGL2PSOpenGL2
  RenderingOpenGL2
  RenderingVolumeOpenGL2
)

if (NOT VTK_FOUND)
  message(FATAL_ERROR "MultiBlockVolumeMapper: Unable to find the VTK build folder.")
endif()

# Prevent a "command line is too long" failure in Windows.
set(CMAKE_NINJA_FORCE_RESPONSE_FILE "ON" CACHE BOOL "Force Ninja to use response files.")
add_executable(MultiBlockVolumeMapper MACOSX_BUNDLE MultiBlockVolumeMapper.cxx )
  target_link_libraries(MultiBlockVolumeMapper PRIVATE ${VTK_LIBRARIES}
)
# vtk_module_autoinit is needed
vtk_module_autoinit(
  TARGETS MultiBlockVolumeMapper
  MODULES ${VTK_LIBRARIES}
)

Download and Build MultiBlockVolumeMapper

Click here to download MultiBlockVolumeMapper and its CMakeLists.txt file. Once the tarball MultiBlockVolumeMapper.tar has been downloaded and extracted,

cd MultiBlockVolumeMapper/build

If VTK is installed:

cmake ..

If VTK is not installed but compiled on your system, you will need to specify the path to your VTK build:

cmake -DVTK_DIR:PATH=/home/me/vtk_build ..

Build the project:

make

and run it:

./MultiBlockVolumeMapper

WINDOWS USERS

Be sure to add the VTK bin directory to your path. This will resolve the VTK dll's at run time.