Volume Tools Manual

Table of Contents

About

Volumes can be created and edited with specific commands and functions provided in the maxon::VolumeToolsInterface.

Commands

These commands can be used to handle volume data (see Commands Manual):

  • maxon::CommandClasses::VOLUMETOMESH : Converts a VolumeObject into a PolygonObject. See ::VOLUMETOMESHSETTINGS.
  • maxon::CommandClasses::MESHTOVOLUME : Converts a PolygonObject into a VolumeObject LevelSet. See ::MESHTOVOLUMESETTINGS.
  • maxon::CommandClasses::VOLUMEBOOLE : Performs a boolean operation on VolumeObjects (SDF). See ::BOOLESETTINGS, ::BOOLTYPE.
  • maxon::CommandClasses::MIX : Performs a mix operation on Fog VolumeObjects (Fog). See ::MIXSETTINGS. MIXTYPE.
  • maxon::CommandClasses::PARTICLESTOVOLUME : Converts Particle Objects and TP groups to A VolumeObject LevelSet. See ::PARTICLESTOVOLUMESETTINGS.
  • maxon::CommandClasses::SPLINETOVOLUME : Converts Spline Objects to A VolumeObject LevelSet. See ::SPLINETOVOLUMESETTINGS.
  • maxon::CommandClasses::FILTER : FilterSettings a float grid VolumeObject. See ::FILTERSETTINGS.
  • maxon::CommandClasses::SDFFILTER : Filters a float grid SDF VolumeObject. See ::SDFFILTERSETTINGS.
  • maxon::CommandClasses::SDFTOFOG : Converts a SDF Volume to a Fog Volume. See ::SDFTOFOGSETTINGS.
  • maxon::CommandClasses::FOGTOSDF : Converts a Fog Volume to a SDF Volume. See ::FOGTOSDFSETTINGS.
  • maxon::CommandClasses::RESAMPLE : Resamples a Volume to a new grid size. See ::RESAMPLESETTINGS, ::RESAMPLEINTERPOLATIONTYPE.
  • maxon::CommandClasses::FIELDTOVOLUME : Converts a Field to a Fog Volume. See ::FIELDTOVOLUMESETTINGS.
  • maxon::CommandClasses::CREATESPHEREVOLUME : Creates a sphere volume. See ::CREATESPHEREVOLUMESETTINGS.
  • maxon::CommandClasses::CREATEPLATONICVOLUME : Creates a platonic volume. See ::CREATEPLATONICVOLUMESETTINGS.

The maxon::VolumeCommandData structure has these members:

// This example performs multiple commands to turn the
// given polygon objects into volumes, to perform a
// boolean operation on these volumes and to create
// a polygon hull for the result volume.
VolumeObject* volumeObjectA = nullptr;
VolumeObject* volumeObjectB = nullptr;
VolumeObject* resultVolume = nullptr;
{
// make volume objects
maxon::LegacyCommandDataRef context = maxon::LegacyCommandDataClasses::VOLUMEDATA().Create() iferr_return;
sourceObjects.Append(polyObjectA) iferr_return;
sourceObjects.Append(polyObjectB) iferr_return;
data.op = &sourceObjects;
const maxon::Int dataIndex = 0;
context.SetLegacyData<maxon::VolumeCommandData>(data, dataIndex) iferr_return;
const auto command = maxon::CommandClasses::MESHTOVOLUME();
const maxon::COMMANDRESULT res = context.Invoke(command, false) iferr_return;
return maxon::OK;
if (result.result.GetCount() == 2)
{
volumeObjectA = static_cast<VolumeObject*>(result.result[0]);
volumeObjectB = static_cast<VolumeObject*>(result.result[1]);
}
}
{
// perform bool operation
maxon::LegacyCommandDataRef context = maxon::LegacyCommandDataClasses::VOLUMEDATA().Create() iferr_return;
sourceObjects.Append(volumeObjectA) iferr_return;
sourceObjects.Append(volumeObjectB) iferr_return;
data.op = &sourceObjects;
const maxon::Int dataIndex = 0;
// 1 equals BOOLTYPE::DIFF
context.SetLegacyData<maxon::VolumeCommandData>(data, dataIndex) iferr_return;
const auto command = maxon::CommandClasses::BOOLE();
const maxon::COMMANDRESULT res = context.Invoke(command, false) iferr_return;
return maxon::OK;
if (result.result.GetCount() == 1)
{
resultVolume = static_cast<VolumeObject*>(result.result[0]);
}
}
{
// create mesh
maxon::LegacyCommandDataRef context = maxon::LegacyCommandDataClasses::VOLUMEDATA().Create() iferr_return;
sourceObjects.Append(resultVolume) iferr_return;
data.op = &sourceObjects;
const maxon::Int dataIndex = 0;
context.SetLegacyData<maxon::VolumeCommandData>(data, dataIndex) iferr_return;
const auto command = maxon::CommandClasses::VOLUMETOMESH();
const maxon::COMMANDRESULT res = context.Invoke(command, false) iferr_return;
return maxon::OK;
if (result.result.GetCount() == 1)
{
BaseObject* const object = result.result[0];
doc->InsertObject(object, nullptr, nullptr);
}
}
// free data
VolumeObject::Free(resultVolume);
VolumeObject::Free(volumeObjectA);
VolumeObject::Free(volumeObjectB);
Definition: basearray.h:415
MAXON_ATTRIBUTE_FORCE_INLINE ResultRef< T > Append(ARG &&x)
Appends a new element at the end of the array and constructs it using the forwarded value.
Definition: basearray.h:627
PyObject PyObject * result
Definition: abstract.h:43
Py_UCS4 * res
Definition: unicodeobject.h:1113
GRIDSIZE
::Float Grid voxel cube size.
Definition: ge_prepass.h:1
BOOLETYPE
::Int32 The Boole type (union, difference, intersection).
Definition: ge_prepass.h:1
Int64 Int
signed 32/64 bit int, size depends on the platform
Definition: apibase.h:187
#define MAXON_SCOPE
Definition: apibase.h:2891
return OK
Definition: apibase.h:2740
COMMANDRESULT
Defines the result of the command after execution.
Definition: commandbase.h:37
@ OK
The command was executed properly.
void * context
Definition: pycapsule.h:49
const char * doc
Definition: pyerrors.h:226
#define iferr_return
Definition: resultbase.h:1531
Definition: volumecommands.h:24
BaseArray< cinema::BaseObject * > * op
Definition: volumecommands.h:40

Tools

The maxon::VolumeToolsInterface provides multiple functions to handle volumes.

Load volumes from files:

See also maxon::VolumeInterface::CreateFromFile() (VolumeInterface Manual).

Volume operations:

Volume creation:

Volume conversion:

// This example uses multiple tools to turn the
// given polygon objects into volumes, to perform a
// boolean operation on these volumes and to create
// a polygon hull for the result volume.
// lambda funtion to convert the given PolygonObject to a VolumeRef
auto PolyToVolume = [](PolygonObject* const poly) -> maxon::Result<maxon::Volume>
{
// check polygon object data
const Vector* const points = poly->GetPointR();
const CPolygon* const polys = poly->GetPolygonR();
const maxon::Bool noPoints = points == nullptr;
const maxon::Bool noPolys = polys == nullptr;
if (noPoints || noPolys)
return maxon::UnexpectedError(MAXON_SOURCE_LOCATION);
// get polygon object data
const Int32 pointCount = poly->GetPointCount();
const Int32 polyCount = poly->GetPolygonCount();
const Matrix objectMatrix = poly->GetMg();
// point array
volPoints.Resize(pointCount, flags) iferr_return;
// copy point data
for (Int32 pointIndex = 0; pointIndex < pointCount; ++pointIndex)
volPoints[pointIndex] = objectMatrix * points[pointIndex];
// polygon array
volPolys.Resize(polyCount, flags) iferr_return;
// copy polygon data
for (Int32 polyIndex = 0; polyIndex < polyCount; polyIndex++)
{
volPolys[polyIndex] = *reinterpret_cast<const maxon::VolumeConversionPolygon*>(&polys[polyIndex]);
if (polys[polyIndex].IsTriangle())
volPolys[polyIndex].SetTriangle();
}
const maxon::ThreadInterface* const thread = maxon::ThreadRef::GetCurrentThread().GetPointer();
if (thread == nullptr)
return maxon::UnexpectedError(MAXON_SOURCE_LOCATION);
const maxon::ThreadRef threadRef = const_cast<maxon::ThreadInterface*>(thread);
return maxon::VolumeToolsInterface::MeshToVolume(volPoints, volPolys, objectMatrix, 10.0, 10, 10, threadRef);
};
// convert polygon objects to volumes
const maxon::Volume volumeA = PolyToVolume(polyObjectA) iferr_return;
const maxon::Volume volumeB = PolyToVolume(polyObjectB) iferr_return;
// perform bool
const maxon::Volume resultVolume = maxon::VolumeToolsInterface::BoolVolumes(volumeA, volumeB, maxon::BOOLTYPE::DIFF) iferr_return;
// result to mesh
PolygonObject* const mesh = maxon::VolumeToolsInterface::VolumeToMesh(resultVolume, 10.0, 10.0) iferr_return;
if (mesh == nullptr)
return maxon::UnexpectedError(MAXON_SOURCE_LOCATION);
doc->InsertObject(mesh, nullptr, nullptr);
PyCompilerFlags * flags
Definition: ast.h:14
ResultMem Resize(Int newCnt, COLLECTION_RESIZE_FLAGS resizeFlags=COLLECTION_RESIZE_FLAGS::DEFAULT)
Resizes the array to contain newCnt elements. If newCnt is smaller than GetCount() all extra elements...
Definition: basearray.h:1217
Definition: resultbase.h:766
Definition: thread.h:46
static StrongRef< const ThreadInterface > GetCurrentThread()
Definition: thread.h:366
static MAXON_METHOD Result< Volume > MeshToVolume(const Block< Vector > &vertices, const Block< VolumeConversionPolygon > &polygons, Matrix polygonObjectMatrix, Float gridSize, Int32 bandWidthInterior, Int32 bandWidthExterior, const ThreadRef &checkForCancellation, POLYGONCONVERSIONFLAGS conversionSettings=POLYGONCONVERSIONFLAGS::NONE, const Matrix *creationTransform=nullptr)
static MAXON_METHOD Result< cinema::PolygonObject * > VolumeToMesh(const Volume &volume, Float iso, Float adaptiveValue)
static MAXON_METHOD Result< Volume > BoolVolumes(const Volume &volumeOne, const Volume &volumeTwo, BOOLTYPE type)
bool Bool
boolean type, possible values are only false/true, 8 bit
Definition: apibase.h:180
COLLECTION_RESIZE_FLAGS
Flags for Resize(). Depending on the type of collection the flags might be ignored (except for ON_GRO...
Definition: collection.h:126
@ ON_GROW_UNINITIALIZED
Do not initialize added elements (usually PODs) when resizing the array (is supported by all collecti...
#define MAXON_SOURCE_LOCATION
Definition: memoryallocationbase.h:69
maxon::Int32 Int32
Definition: ge_sys_math.h:51
maxon::Mat3< maxon::Vector64 > Matrix
Definition: ge_math.h:159
maxon::Vec3< maxon::Float64, 1 > Vector
Definition: ge_math.h:140
The maxon namespace contains all declarations of the Maxon API.
Definition: autoweight.h:21
#define iferr_scope
Definition: resultbase.h:1396
Definition: volumetools.h:193
// This example creates a vector volume from the given field object.
// prepare conversion
sampleData.doc = doc;
sampleData.fieldList = nullptr;
sampleData.fieldOwner = fieldObject;
sampleData.extraTransform = fieldObject->GetMg();
sampleBox.minValue = maxon::Vector { -100.0 };
sampleBox.maxValue = maxon::Vector { 100.0 };
const maxon::Float gridSize = 10.0;
// convert
const maxon::Volume volume = maxon::VolumeToolsInterface::ConvertFieldsToVectorVolume(sampleData, gridSize, sampleBox, thread, nullptr, nullptr) iferr_return;
// make volume object
VolumeObject* const volumeObject = VolumeObject::Alloc();
if (volumeObject == nullptr)
return maxon::OutOfMemoryError(MAXON_SOURCE_LOCATION);
doc->InsertObject(volumeObject, nullptr, nullptr);
// store volume data
volumeObject->SetVolume(volume);
Definition: range.h:26
T maxValue
The inclusive maximum boundary of this range. If the minimum boundary is not less than or equal to th...
Definition: range.h:257
T minValue
The inclusive minimum boundary of this range.
Definition: range.h:256
static MAXON_METHOD Result< Volume > ConvertFieldsToVectorVolume(FieldSampleData &fieldData, Float gridSize, const Range< Vector > &sampleBox, const ThreadRef &checkForCancellation, const Volume *volumeReference=nullptr, const Matrix *creationTransform=nullptr)
Float64 Float
Definition: apibase.h:196
@ NONE
Default state.
Definition: volumetools.h:177
FIELDLAYER_FLAG flags
Definition: volumetools.h:180
const cinema::BaseDocument * doc
Definition: volumetools.h:184
Matrix extraTransform
Definition: volumetools.h:179
const cinema::FieldList * fieldList
Definition: volumetools.h:182
const cinema::BaseList2D * fieldOwner
Definition: volumetools.h:183

Further Reading