VTK  9.5.20251215
vtkCompositeDataDisplayAttributes.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-License-Identifier: BSD-3-Clause
36
37#ifndef vtkCompositeDataDisplayAttributes_h
38#define vtkCompositeDataDisplayAttributes_h
39
40#include "vtkObject.h"
41
42#include "vtkColor.h" // for vtkColor3d
43#include "vtkRenderingCoreModule.h" // for export macro
44#include "vtkSmartPointer.h" // for arg
45#include "vtkVector.h" // for vtkVector2d
46#include "vtkWrappingHints.h" // For VTK_MARSHALMANUAL
47
48#include <functional> // for std::function
49#include <unordered_map> // for std::unordered_map
50
51VTK_ABI_NAMESPACE_BEGIN
52class vtkBoundingBox;
53class vtkDataObject;
54class vtkDeserializer;
56class vtkSerializer;
57class vtkTexture;
58
60{
61public:
64 void PrintSelf(ostream& os, vtkIndent indent) override;
65
70
72
75 void SetBlockVisibility(vtkDataObject* data_object, bool visible);
76 bool GetBlockVisibility(vtkDataObject* data_object) const;
78
83 bool HasBlockVisibility(vtkDataObject* data_object) const;
84
89
95
100
102
105 void SetBlockPickability(vtkDataObject* data_object, bool visible);
106 bool GetBlockPickability(vtkDataObject* data_object) const;
108
113 bool HasBlockPickability(vtkDataObject* data_object) const;
114
119
125
127
130 void SetBlockScalarVisibility(vtkDataObject* data_object, bool value);
131 bool GetBlockScalarVisibility(vtkDataObject* data_object) const;
132 bool HasBlockScalarVisibility(vtkDataObject* data_object) const;
137
139
142 void SetBlockUseLookupTableScalarRange(vtkDataObject* data_object, bool value);
149
151
161
163
166 void SetBlockColor(vtkDataObject* data_object, const double color[3]);
167 void GetBlockColor(vtkDataObject* data_object, double color[3]) const;
170
174 bool HasBlockColors() const;
175
179 bool HasBlockColor(vtkDataObject* data_object) const;
180
184 void RemoveBlockColor(vtkDataObject* data_object);
185
190
192
195 void SetBlockOpacity(vtkDataObject* data_object, double opacity);
196 double GetBlockOpacity(vtkDataObject* data_object) const;
198
202 bool HasBlockOpacities() const;
203
207 bool HasBlockOpacity(vtkDataObject* data_object) const;
208
213
218
220
224 void SetBlockMaterial(vtkDataObject* data_object, const std::string& material);
225 const std::string& GetBlockMaterial(vtkDataObject* data_object) const;
227
231 bool HasBlockMaterials() const;
232
236 bool HasBlockMaterial(vtkDataObject* data_object) const;
237
242
247
249
252 void SetBlockColorMode(vtkDataObject* data_object, int value);
253 int GetBlockColorMode(vtkDataObject* data_object) const;
254 bool HasBlockColorMode(vtkDataObject* data_object) const;
255 bool HasBlockColorModes() const;
259
261
264 void SetBlockScalarMode(vtkDataObject* data_object, int value);
265 int GetBlockScalarMode(vtkDataObject* data_object) const;
266 bool HasBlockScalarMode(vtkDataObject* data_object) const;
271
273
276 void SetBlockArrayAccessMode(vtkDataObject* data_object, int value);
277 int GetBlockArrayAccessMode(vtkDataObject* data_object) const;
278 bool HasBlockArrayAccessMode(vtkDataObject* data_object) const;
283
285
288 void SetBlockArrayComponent(vtkDataObject* data_object, int value);
289 int GetBlockArrayComponent(vtkDataObject* data_object) const;
290 bool HasBlockArrayComponent(vtkDataObject* data_object) const;
295
297
300 void SetBlockArrayId(vtkDataObject* data_object, int value);
301 int GetBlockArrayId(vtkDataObject* data_object) const;
302 bool HasBlockArrayId(vtkDataObject* data_object) const;
303 bool HasBlockArrayIds() const;
307
309
312 void SetBlockScalarRange(vtkDataObject* data_object, const vtkVector2d& value);
314 bool HasBlockScalarRange(vtkDataObject* data_object) const;
319
321
324 void SetBlockArrayName(vtkDataObject* data_object, const std::string& value);
325 std::string GetBlockArrayName(vtkDataObject* data_object) const;
326 bool HasBlockArrayName(vtkDataObject* data_object) const;
327 bool HasBlockArrayNames() const;
331
333
338 bool HasBlockFieldDataTupleId(vtkDataObject* data_object) const;
343
345
350 bool HasBlockLookupTable(vtkDataObject* data_object) const;
355
357
363 bool HasBlockTexture(vtkDataObject* dataObject) const;
364 bool HasBlockTextures() const;
368
376 vtkCompositeDataDisplayAttributes* cda, vtkDataObject* dobj, double bounds[6]);
377
383 unsigned int flat_index, vtkDataObject* parent_obj, unsigned int current_flat_index = 0);
384
385 void VisitVisibilities(std::function<bool(vtkDataObject*, bool)> visitor)
386 {
387 for (auto entry : this->BlockVisibilities)
388 {
389 if (visitor(entry.first, entry.second))
390 {
391 break;
392 }
393 }
394 }
395
396protected:
399
400private:
402 void operator=(const vtkCompositeDataDisplayAttributes&) = delete;
403
412 static void ComputeVisibleBoundsInternal(vtkCompositeDataDisplayAttributes* cda,
413 vtkDataObject* dobj, vtkBoundingBox* bbox, bool parentVisible = true);
414
415 using BoolMap = std::unordered_map<vtkDataObject*, bool>;
416 using DoubleMap = std::unordered_map<vtkDataObject*, double>;
417 using IntMap = std::unordered_map<vtkDataObject*, int>;
418 using VtkIdTypeMap = std::unordered_map<vtkDataObject*, vtkIdType>;
419 using ColorMap = std::unordered_map<vtkDataObject*, vtkColor3d>;
420 using RangeMap = std::unordered_map<vtkDataObject*, vtkVector2d>;
421 using StringMap = std::unordered_map<vtkDataObject*, std::string>;
422 using LookupTableMap = std::unordered_map<vtkDataObject*, vtkSmartPointer<vtkScalarsToColors>>;
423 using TextureMap = std::unordered_map<vtkDataObject*, vtkSmartPointer<vtkTexture>>;
424
425 BoolMap BlockVisibilities;
426 ColorMap BlockColors;
427 DoubleMap BlockOpacities;
428 StringMap BlockMaterials;
429 BoolMap BlockPickabilities;
430 BoolMap BlockScalarVisibilities;
431 BoolMap BlockUseLookupTableScalarRanges;
432 BoolMap BlockInterpolateScalarsBeforeMappings;
433 IntMap BlockColorModes;
434 IntMap BlockScalarModes;
435 IntMap BlockArrayAccessModes;
436 IntMap BlockArrayComponents;
437 IntMap BlockArrayIds;
438 RangeMap BlockScalarRanges;
439 StringMap BlockArrayNames;
440 LookupTableMap BlockLookupTables;
441 VtkIdTypeMap BlockFieldDataTupleIds;
442 TextureMap BlockTextures;
443
445};
446
447VTK_ABI_NAMESPACE_END
448#endif // vtkCompositeDataDisplayAttributes_h
Fast, simple class for representing and operating on 3D bounds.
void SetBlockColorMode(vtkDataObject *data_object, int value)
bool GetBlockPickability(vtkDataObject *data_object) const
Set/get the pickability for the block with data_object.
void SetBlockMaterial(vtkDataObject *data_object, const std::string &material)
Set/get the material for the block with data_object.
void SetBlockScalarVisibility(vtkDataObject *data_object, bool value)
bool HasBlockOpacities() const
Returns true if any block has an opacity set.
int GetBlockArrayId(vtkDataObject *data_object) const
bool HasBlockVisibilities() const
Returns true if any block has any block visibility is set.
bool HasBlockMaterials() const
Returns true if any block has an material set.
void RemoveBlockArrayId(vtkDataObject *data_object)
vtkSmartPointer< vtkTexture > GetBlockTexture(vtkDataObject *dataObject) const
Functions to Get/Set/Remove a texture image for a specific data object block given by the dataObject ...
void RemoveBlockFieldDataTupleId(vtkDataObject *data_object)
bool HasBlockScalarRange(vtkDataObject *data_object) const
bool HasBlockTextures() const
Functions to Get/Set/Remove a texture image for a specific data object block given by the dataObject ...
vtkIdType GetBlockFieldDataTupleId(vtkDataObject *data_object) const
void SetBlockOpacity(vtkDataObject *data_object, double opacity)
Set/get the opacity for the block with data_object.
void SetBlockUseLookupTableScalarRange(vtkDataObject *data_object, bool value)
void RemoveBlockArrayName(vtkDataObject *data_object)
void SetBlockColor(vtkDataObject *data_object, const double color[3])
Set/get the color for the block with data_object.
bool HasBlockArrayName(vtkDataObject *data_object) const
void SetBlockScalarMode(vtkDataObject *data_object, int value)
void SetBlockVisibility(vtkDataObject *data_object, bool visible)
Set/get the visibility for the block with data_object.
void RemoveBlockLookupTable(vtkDataObject *data_object)
bool GetBlockVisibility(vtkDataObject *data_object) const
Set/get the visibility for the block with data_object.
void SetBlockPickability(vtkDataObject *data_object, bool visible)
Set/get the pickability for the block with data_object.
void SetBlockArrayComponent(vtkDataObject *data_object, int value)
void RemoveBlockVisibilities()
Removes all block visibility flags.
bool HasBlockArrayId(vtkDataObject *data_object) const
bool HasBlockOpacity(vtkDataObject *data_object) const
Returns true if the block with data_object has an opacity set.
bool HasBlockPickability(vtkDataObject *data_object) const
Returns true if the block with the given data_object has a pickability set.
static vtkCompositeDataDisplayAttributes * New()
void SetBlockTexture(vtkDataObject *dataObject, vtkSmartPointer< vtkTexture > texture)
Functions to Get/Set/Remove a texture image for a specific data object block given by the dataObject ...
void RemoveBlockOpacities()
Removes all block opacities.
void RemoveBlockColor(vtkDataObject *data_object)
Removes the block color for the block with data_object.
void RemoveBlockScalarVisibility(vtkDataObject *data_object)
void GetBlockColor(vtkDataObject *data_object, double color[3]) const
Set/get the color for the block with data_object.
std::string GetBlockArrayName(vtkDataObject *data_object) const
void VisitVisibilities(std::function< bool(vtkDataObject *, bool)> visitor)
bool GetBlockScalarVisibility(vtkDataObject *data_object) const
void RemoveBlockInterpolateScalarsBeforeMapping(vtkDataObject *data_object)
void SetBlockArrayName(vtkDataObject *data_object, const std::string &value)
double GetBlockOpacity(vtkDataObject *data_object) const
Set/get the opacity for the block with data_object.
bool HasBlockInterpolateScalarsBeforeMapping(vtkDataObject *data_object) const
void SetBlockFieldDataTupleId(vtkDataObject *data_object, vtkIdType value)
bool HasBlockUseLookupTableScalarRange(vtkDataObject *data_object) const
bool HasBlockUseLookupTableScalarRanges() const
bool HasBlockColor(vtkDataObject *data_object) const
Returns true if the block with the given data_object has a color.
void SetBlockArrayAccessMode(vtkDataObject *data_object, int value)
bool GetBlockUseLookupTableScalarRange(vtkDataObject *data_object) const
void SetBlockLookupTable(vtkDataObject *data_object, vtkSmartPointer< vtkScalarsToColors > lut)
bool HasBlockInterpolateScalarsBeforeMappings() const
void RemoveBlockTextures()
Functions to Get/Set/Remove a texture image for a specific data object block given by the dataObject ...
void RemoveBlockMaterial(vtkDataObject *data_object)
Removes the set material for the block with data_object.
const std::string & GetBlockMaterial(vtkDataObject *data_object) const
Set/get the material for the block with data_object.
void RemoveBlockUseLookupTableScalarRange(vtkDataObject *data_object)
void RemoveBlockTexture(vtkDataObject *dataObject)
Functions to Get/Set/Remove a texture image for a specific data object block given by the dataObject ...
void RemoveBlockScalarRange(vtkDataObject *data_object)
bool HasBlockLookupTable(vtkDataObject *data_object) const
void RemoveBlockOpacity(vtkDataObject *data_object)
Removes the set opacity for the block with data_object.
bool HasBlockVisibility(vtkDataObject *data_object) const
Returns true if the block with the given data_object has a visibility set.
int GetBlockColorMode(vtkDataObject *data_object) const
int GetBlockArrayAccessMode(vtkDataObject *data_object) const
void RemoveBlockMaterials()
Removes all block materialss.
vtkVector2d GetBlockScalarRange(vtkDataObject *data_object) const
bool HasBlockFieldDataTupleId(vtkDataObject *data_object) const
bool HasBlockPickabilities() const
Returns true if any block has any block pickability is set.
bool HasBlockArrayAccessMode(vtkDataObject *data_object) const
int GetBlockScalarMode(vtkDataObject *data_object) const
bool GetBlockInterpolateScalarsBeforeMapping(vtkDataObject *data_object) const
void SetBlockScalarRange(vtkDataObject *data_object, const vtkVector2d &value)
void RemoveBlockScalarMode(vtkDataObject *data_object)
void RemoveBlockColorMode(vtkDataObject *data_object)
bool HasBlockColors() const
Returns true if any block has any block color is set.
bool HasBlockScalarVisibility(vtkDataObject *data_object) const
void RemoveBlockPickabilities()
Removes all block pickability flags.
bool HasBlockScalarMode(vtkDataObject *data_object) const
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
void RemoveBlockVisibility(vtkDataObject *data_object)
Removes the block visibility flag for the block with data_object.
static void ComputeVisibleBounds(vtkCompositeDataDisplayAttributes *cda, vtkDataObject *dobj, double bounds[6])
If the input dobj is a vtkCompositeDataSet, we will loop over the hierarchy recursively starting from...
static vtkDataObject * DataObjectFromIndex(unsigned int flat_index, vtkDataObject *parent_obj, unsigned int current_flat_index=0)
Get the DataObject corresponding to the node with index flat_index under parent_obj.
void SetBlockInterpolateScalarsBeforeMapping(vtkDataObject *data_object, bool value)
bool HasBlockColorMode(vtkDataObject *data_object) const
bool HasBlockMaterial(vtkDataObject *data_object) const
Returns true if the block with data_object has an material set.
int GetBlockArrayComponent(vtkDataObject *data_object) const
bool HasBlockTexture(vtkDataObject *dataObject) const
Functions to Get/Set/Remove a texture image for a specific data object block given by the dataObject ...
void RemoveBlockArrayComponent(vtkDataObject *data_object)
void SetBlockArrayId(vtkDataObject *data_object, int value)
void RemoveBlockPickability(vtkDataObject *data_object)
Removes the block pickability flag for the block with data_object.
vtkSmartPointer< vtkScalarsToColors > GetBlockLookupTable(vtkDataObject *data_object) const
void RemoveBlockArrayAccessMode(vtkDataObject *data_object)
bool HasBlockArrayComponent(vtkDataObject *data_object) const
vtkColor3d GetBlockColor(vtkDataObject *data_object) const
Set/get the color for the block with data_object.
void RemoveBlockColors()
Removes all block colors.
general representation of visualization data
Deserialize VTK objects from JSON.
a simple class to control print indentation
Definition vtkIndent.h:108
Superclass for mapping scalar values to colors.
Serialize VTK objects to JSON.
Hold a reference to a vtkObjectBase instance.
handles properties associated with a texture map
Definition vtkTexture.h:168
int vtkIdType
Definition vtkType.h:368
#define VTK_MARSHALMANUAL