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.