MeshLib
 
Loading...
Searching...
No Matches
MR::ObjectMeshHolder Class Reference

#include <MRObjectMeshHolder.h>

+ Inheritance diagram for MR::ObjectMeshHolder:

Public Types

using SelectionChangedSignal = Signal<void()>
 signal about face selection changing, triggered in selectFaces
 
- Public Types inherited from MR::Object
using XfChangedSignal = Signal<void() >
 

Public Member Functions

MRMESH_API ObjectMeshHolder ()
 
 ObjectMeshHolder (ObjectMeshHolder &&) noexcept=default
 
ObjectMeshHolderoperator= (ObjectMeshHolder &&) noexcept=default
 
virtual const char * typeName () const override
 
virtual MRMESH_API void applyScale (float scaleFactor) override
 scale object size (all point positions)
 
virtual MRMESH_API bool hasVisualRepresentation () const override
 mesh object can be seen if the mesh has at least one edge
 
virtual bool hasModel () const override
 
const std::shared_ptr< const Mesh > & mesh () const
 
MeshPart meshPart () const
 
virtual MRMESH_API std::shared_ptr< Objectclone () const override
 
virtual MRMESH_API std::shared_ptr< ObjectshallowClone () const override
 
virtual MRMESH_API void setDirtyFlags (uint32_t mask, bool invalidateCaches=true) override
 
const FaceBitSetgetSelectedFaces () const
 
virtual MRMESH_API void selectFaces (FaceBitSet newSelection)
 
MRMESH_API const ColorgetSelectedFacesColor (ViewportId id={}) const
 returns colors of selected triangles
 
virtual MRMESH_API void setSelectedFacesColor (const Color &color, ViewportId id={})
 sets colors of selected triangles
 
const UndirectedEdgeBitSet & getSelectedEdges () const
 
virtual MRMESH_API void selectEdges (UndirectedEdgeBitSet newSelection)
 
MRMESH_API const ColorgetSelectedEdgesColor (ViewportId id={}) const
 returns colors of selected edges
 
virtual MRMESH_API void setSelectedEdgesColor (const Color &color, ViewportId id={})
 sets colors of selected edges
 
MRMESH_API const ViewportProperty< Color > & getSelectedEdgesColorsForAllViewports () const
 
virtual MRMESH_API void setSelectedEdgesColorsForAllViewports (ViewportProperty< Color > val)
 
MRMESH_API const ViewportProperty< Color > & getSelectedFacesColorsForAllViewports () const
 
virtual MRMESH_API void setSelectedFacesColorsForAllViewports (ViewportProperty< Color > val)
 
MRMESH_API const ViewportProperty< Color > & getEdgesColorsForAllViewports () const
 
virtual MRMESH_API void setEdgesColorsForAllViewports (ViewportProperty< Color > val)
 
MRMESH_API const ViewportProperty< Color > & getBordersColorsForAllViewports () const
 
virtual MRMESH_API void setBordersColorsForAllViewports (ViewportProperty< Color > val)
 
const UndirectedEdgeBitSet & creases () const
 Edges on mesh, that will have sharp visualization even with smooth shading.
 
virtual MRMESH_API void setCreases (UndirectedEdgeBitSet creases)
 
void setFlatShading (bool on)
 sets flat (true) or smooth (false) shading
 
bool flatShading () const
 
MRMESH_API bool supportsVisualizeProperty (AnyVisualizeMaskEnum type) const override
 Returns true if this class supports the property type. Otherwise passing it to the functions below is illegal.
 
MRMESH_API AllVisualizeProperties getAllVisualizeProperties () const override
 get all visualize properties masks
 
MRMESH_API const ViewportMaskgetVisualizePropertyMask (AnyVisualizeMaskEnum type) const override
 returns mask of viewports where given property is set
 
const FaceColors & getFacesColorMap () const
 
virtual void setFacesColorMap (FaceColors facesColorMap)
 
virtual void updateFacesColorMap (FaceColors &updated)
 
virtual MRMESH_API void setEdgeWidth (float edgeWidth)
 
float getEdgeWidth () const
 
virtual MRMESH_API void setPointSize (float size)
 
virtual float getPointSize () const
 
const ColorgetEdgesColor (ViewportId id={}) const
 
virtual void setEdgesColor (const Color &color, ViewportId id={})
 
const ColorgetPointsColor (ViewportId id={}) const
 
virtual void setPointsColor (const Color &color, ViewportId id={})
 
const ColorgetBordersColor (ViewportId id={}) const
 
virtual void setBordersColor (const Color &color, ViewportId id={})
 
 ObjectMeshHolder (ProtectedStruct, const ObjectMeshHolder &obj)
 
MRMESH_API const MeshTexturegetTexture () const
 returns first texture in the vector. If there is no textures, returns empty texture
 
virtual MRMESH_API void setTexture (MeshTexture texture)
 
virtual MRMESH_API void updateTexture (MeshTexture &updated)
 
const Vector< MeshTexture, TextureId > & getTextures () const
 
virtual void setTextures (Vector< MeshTexture, TextureId > texture)
 
virtual void updateTextures (Vector< MeshTexture, TextureId > &updated)
 
virtual void setTexturePerFace (Vector< TextureId, FaceId > texturePerFace)
 
virtual void updateTexturePerFace (Vector< TextureId, FaceId > &texturePerFace)
 
virtual void addTexture (MeshTexture texture)
 
const TexturePerFace & getTexturePerFace () const
 
const VertUVCoords & getUVCoords () const
 
virtual void setUVCoords (VertUVCoords uvCoordinates)
 
virtual void updateUVCoords (VertUVCoords &updated)
 
virtual MRMESH_API void copyTextureAndColors (const ObjectMeshHolder &src, const VertMap &thisToSrc, const FaceMap &thisToSrcFaces={})
 copies texture, UV-coordinates and vertex colors from given source object
 
MRMESH_API void copyColors (const VisualObject &src, const VertMap &thisToSrc, const FaceMap &thisToSrcFaces={}) override
 copies point colors from given source object
 
const MeshTexturegetAncillaryTexture () const
 
virtual void setAncillaryTexture (MeshTexture texture)
 
const VertUVCoords & getAncillaryUVCoords () const
 
virtual void setAncillaryUVCoords (VertUVCoords uvCoordinates)
 
void updateAncillaryUVCoords (VertUVCoords &updated)
 
bool hasAncillaryTexture () const
 
MRMESH_API void clearAncillaryTexture ()
 
MRMESH_API uint32_t getNeededNormalsRenderDirtyValue (ViewportMask viewportMask) const
 returns dirty flag of currently using normal type if they are dirty in render representation
 
virtual MRMESH_API bool getRedrawFlag (ViewportMask viewportMask) const override
 returns true if the object must be redrawn (due to dirty flags) in one of specified viewports
 
virtual MRMESH_API void resetDirtyExeptMask (uint32_t mask) const
 reset dirty flags without some specific bits (useful for lazy normals update)
 
MRMESH_API bool isMeshClosed () const
 returns cached information whether the mesh is closed
 
virtual MRMESH_API Box3f getWorldBox (ViewportId={}) const override
 
MRMESH_API size_t numSelectedFaces () const
 returns cached information about the number of selected faces in the mesh
 
MRMESH_API size_t numSelectedEdges () const
 returns cached information about the number of selected undirected edges in the mesh
 
MRMESH_API size_t numCreaseEdges () const
 returns cached information about the number of crease undirected edges in the mesh
 
MRMESH_API double totalArea () const
 returns cached summed area of mesh triangles
 
MRMESH_API double selectedArea () const
 returns cached area of selected triangles
 
MRMESH_API double volume () const
 returns cached volume of space surrounded by the mesh, which is valid only if mesh is closed
 
MRMESH_API float avgEdgeLen () const
 returns cached average edge length
 
MRMESH_API size_t numUndirectedEdges () const
 returns cached information about the number of undirected edges in the mesh
 
MRMESH_API size_t numHoles () const
 returns cached information about the number of holes in the mesh
 
MRMESH_API size_t numComponents () const
 returns cached information about the number of components in the mesh
 
MRMESH_API size_t numHandles () const
 returns cached information about the number of handles in the mesh
 
virtual MRMESH_API size_t heapBytes () const override
 returns the amount of memory this object occupies on heap
 
const char * saveMeshFormat () const
 returns file extension used to serialize the mesh
 
MRMESH_API void setSaveMeshFormat (const char *newFormat)
 sets file extension used to serialize the mesh: must be not null and must start from '.'
 
- Public Member Functions inherited from MR::VisualObject
MRMESH_API VisualObject ()
 
 VisualObject (VisualObject &&)=default
 
VisualObjectoperator= (VisualObject &&)=default
 
virtual ~VisualObject ()=default
 
virtual std::string getClassName () const override
 return human readable name of subclass
 
MRMESH_API void setVisualizeProperty (bool value, AnyVisualizeMaskEnum type, ViewportMask viewportMask)
 set visual property in all viewports specified by the mask
 
virtual MRMESH_API void setVisualizePropertyMask (AnyVisualizeMaskEnum type, ViewportMask viewportMask)
 set visual property mask
 
MRMESH_API bool getVisualizeProperty (AnyVisualizeMaskEnum type, ViewportMask viewportMask) const
 returns true if the property is set at least in one viewport specified by the mask
 
MRMESH_API void toggleVisualizeProperty (AnyVisualizeMaskEnum type, ViewportMask viewportMask)
 toggle visual property in all viewports specified by the mask
 
void setAllVisualizeProperties (const AllVisualizeProperties &properties)
 set all visualize properties masks
 
void showLabels (bool on)
 shows/hides labels
 
bool showLabels () const
 
void showName (bool on)
 shows/hides object name in all viewports
 
bool showName () const
 returns whether object name is shown in any viewport
 
MRMESH_API const ColorgetFrontColor (bool selected=true, ViewportId viewportId={}) const
 returns color of object when it is selected/not-selected (depending on argument) in given viewport
 
virtual MRMESH_API void setFrontColor (const Color &color, bool selected, ViewportId viewportId={})
 sets color of object when it is selected/not-selected (depending on argument) in given viewport
 
virtual MRMESH_API const ViewportProperty< Color > & getFrontColorsForAllViewports (bool selected=true) const
 returns color of object when it is selected/not-selected (depending on argument) in all viewports
 
virtual MRMESH_API void setFrontColorsForAllViewports (ViewportProperty< Color > val, bool selected=true)
 sets color of object when it is selected/not-selected (depending on argument) in all viewports
 
virtual MRMESH_API const ViewportProperty< Color > & getBackColorsForAllViewports () const
 returns backward color of object in all viewports
 
virtual MRMESH_API void setBackColorsForAllViewports (ViewportProperty< Color > val)
 sets backward color of object in all viewports
 
MRMESH_API const ColorgetBackColor (ViewportId viewportId={}) const
 returns backward color of object in given viewport
 
virtual MRMESH_API void setBackColor (const Color &color, ViewportId viewportId={})
 sets backward color of object in given viewport
 
MRMESH_API const uint8_t & getGlobalAlpha (ViewportId viewportId={}) const
 returns global transparency alpha of object in given viewport
 
virtual MRMESH_API void setGlobalAlpha (uint8_t alpha, ViewportId viewportId={})
 sets global transparency alpha of object in given viewport
 
virtual MRMESH_API const ViewportProperty< uint8_t > & getGlobalAlphaForAllViewports () const
 returns global transparency alpha of object in all viewports
 
virtual MRMESH_API void setGlobalAlphaForAllViewports (ViewportProperty< uint8_t > val)
 sets global transparency alpha of object in all viewports
 
MRMESH_API const ColorgetLabelsColor (ViewportId viewportId={}) const
 
virtual MRMESH_API void setLabelsColor (const Color &color, ViewportId viewportId={})
 
MRMESH_API const ViewportProperty< Color > & getLabelsColorsForAllViewports () const
 
virtual MRMESH_API void setLabelsColorsForAllViewports (ViewportProperty< Color > val)
 
MRMESH_API uint32_t getDirtyFlags () const
 returns current dirty flags for the object
 
MRMESH_API void resetDirty () const
 resets all dirty flags (except for cache flags that will be reset automatically on cache update)
 
MRMESH_API Box3f getBoundingBox () const
 returns cached bounding box of this object in local coordinates
 
bool isPickable (ViewportMask viewportMask=ViewportMask::any()) const
 whether the object can be picked (by mouse) in any of given viewports
 
virtual MRMESH_API void setPickable (bool on, ViewportMask viewportMask=ViewportMask::all())
 sets the object as can/cannot be picked (by mouse) in all of given viewports
 
const VertColors & getVertsColorMap () const
 returns per-vertex colors of the object
 
virtual void setVertsColorMap (VertColors vertsColorMap)
 sets per-vertex colors of the object
 
virtual void updateVertsColorMap (VertColors &vertsColorMap)
 swaps per-vertex colors of the object with given argument
 
ColoringType getColoringType () const
 returns the current coloring mode of the object
 
virtual MRMESH_API void setColoringType (ColoringType coloringType)
 sets coloring mode of the object with given argument
 
float getShininess () const
 returns the current shininess visual value
 
virtual void setShininess (float shininess)
 sets shininess visual value of the object with given argument
 
float getSpecularStrength () const
 returns intensity of reflections
 
virtual void setSpecularStrength (float specularStrength)
 sets intensity of reflections
 
float getAmbientStrength () const
 returns intensity of non-directional light
 
virtual void setAmbientStrength (float ambientStrength)
 sets intensity of non-directional light
 
const std::vector< PositionedText > & getLabels () const
 
virtual void setLabels (std::vector< PositionedText > labels)
 
virtual MRMESH_API bool render (const ModelRenderParams &) const
 
virtual MRMESH_API void renderForPicker (const ModelBaseRenderParams &, unsigned) const
 draws this object for picking
 
virtual MRMESH_API void renderUi (const UiRenderParams &params) const
 draws this object for 2d UI
 
 VisualObject (ProtectedStruct, const VisualObject &obj)
 this ctor is public only for std::make_shared used inside clone()
 
virtual MRMESH_API std::vector< std::string > getInfoLines () const override
 return several info lines that can better describe the object in the UI
 
MRMESH_API bool useDefaultScenePropertiesOnDeserialization () const
 
MRMESH_API void setUseDefaultScenePropertiesOnDeserialization (bool useDefaultScenePropertiesOnDeserialization)
 
- Public Member Functions inherited from MR::Object
 Object ()=default
 
 Object (Object &&) noexcept=default
 
Objectoperator= (Object &&) noexcept=default
 
virtual ~Object ()=default
 
template<typename T >
T * asType ()
 
template<typename T >
const T * asType () const
 
const std::string & name () const
 
virtual void setName (std::string name)
 
MRMESH_API std::shared_ptr< const Objectfind (const std::string_view &name) const
 finds a direct child by name
 
std::shared_ptr< Objectfind (const std::string_view &name)
 
template<typename T >
std::shared_ptr< const T > find () const
 finds a direct child by type
 
template<typename T >
std::shared_ptr< T > find ()
 
template<typename T >
std::shared_ptr< const T > find (const std::string_view &name) const
 finds a direct child by name and type
 
template<typename T >
std::shared_ptr< T > find (const std::string_view &name)
 
const AffineXf3fxf (ViewportId id={}, bool *isDef=nullptr) const
 
virtual MRMESH_API void setXf (const AffineXf3f &xf, ViewportId id={})
 
virtual MRMESH_API void resetXf (ViewportId id={})
 forgets specific transform in given viewport (or forgets all specific transforms for {} input)
 
const ViewportProperty< AffineXf3f > & xfsForAllViewports () const
 returns xfs for all viewports, combined into a single object
 
virtual void setXfsForAllViewports (ViewportProperty< AffineXf3f > xf)
 modifies xfs for all viewports at once
 
MRMESH_API AffineXf3f worldXf (ViewportId id={}, bool *isDef=nullptr) const
 
MRMESH_API void setWorldXf (const AffineXf3f &xf, ViewportId id={})
 
MRMESH_API ViewportMask globalVisibilityMask () const
 returns all viewports where this object is visible together with all its parents
 
bool globalVisibility (ViewportMask viewportMask=ViewportMask::any()) const
 returns true if this object is visible together with all its parents in any of given viewports
 
MRMESH_API void setGlobalVisibility (bool on, ViewportMask viewportMask=ViewportMask::any())
 if true sets all predecessors visible, otherwise sets this object invisible
 
bool isLocked () const
 object properties lock for UI
 
virtual void setLocked (bool on)
 
bool isParentLocked () const
 
virtual void setParentLocked (bool lock)
 
const Objectparent () const
 returns parent object in the tree
 
Objectparent ()
 
MRMESH_API bool isAncestor (const Object *ancestor) const
 return true if given object is ancestor of this one, false otherwise
 
MRMESH_API ObjectfindCommonAncestor (Object &other)
 
const ObjectfindCommonAncestor (const Object &other) const
 
virtual MRMESH_API bool detachFromParent ()
 
const std::vector< std::shared_ptr< Object > > & children ()
 an object can hold other sub-objects
 
const std::vector< std::shared_ptr< const Object > > & children () const
 
virtual MRMESH_API bool addChild (std::shared_ptr< Object > child, bool recognizedChild=true)
 
virtual MRMESH_API bool addChildBefore (std::shared_ptr< Object > newChild, const std::shared_ptr< Object > &existingChild)
 
bool removeChild (const std::shared_ptr< Object > &child)
 returns false if it was not child of this
 
virtual MRMESH_API bool removeChild (Object *child)
 
virtual MRMESH_API void removeAllChildren ()
 detaches all recognized children from this, keeping all unrecognized ones
 
MRMESH_API void sortChildren ()
 sort recognized children by name
 
virtual MRMESH_API bool select (bool on)
 selects the object, returns true if value changed, otherwise returns false
 
virtual bool isSelected () const
 
virtual MRMESH_API void setAncillary (bool ancillary)
 
bool isAncillary () const
 
MRMESH_API void setVisible (bool on, ViewportMask viewportMask=ViewportMask::all())
 sets the object visible in the viewports specified by the mask (by default in all viewports)
 
bool isVisible (ViewportMask viewportMask=ViewportMask::any()) const
 checks whether the object is visible in any of the viewports specified by the mask (by default in any viewport)
 
virtual MRMESH_API void setVisibilityMask (ViewportMask viewportMask)
 specifies object visibility as bitmask of viewports
 
virtual ViewportMask visibilityMask () const
 gets object visibility as bitmask of viewports
 
void resetRedrawFlag () const
 
MRMESH_API std::shared_ptr< ObjectcloneTree () const
 clones all tree of this object (except ancillary and unrecognized children)
 
MRMESH_API std::shared_ptr< ObjectshallowCloneTree () const
 
MRMESH_API Expected< std::vector< std::future< VoidOrErrStr > > > serializeRecursive (const std::filesystem::path &path, Json::Value &root, int childId) const
 
MRMESH_API VoidOrErrStr deserializeRecursive (const std::filesystem::path &path, const Json::Value &root, ProgressCallback progressCb={}, int *objCounter=nullptr)
 
MRMESH_API void swap (Object &other)
 
MRMESH_API Box3f getWorldTreeBox (ViewportId={}) const
 returns bounding box of this object and all children visible in given (or default) viewport in world coordinates
 
 Object (ProtectedStruct, const Object &obj)
 
- Public Member Functions inherited from MR::ObjectChildrenHolder
 ObjectChildrenHolder ()=default
 
 ObjectChildrenHolder (const ObjectChildrenHolder &) noexcept
 
ObjectChildrenHolderoperator= (const ObjectChildrenHolder &) noexcept
 
MRMESH_API ObjectChildrenHolder (ObjectChildrenHolder &&) noexcept
 
MRMESH_API ObjectChildrenHolderoperator= (ObjectChildrenHolder &&) noexcept
 
MRMESH_API ~ObjectChildrenHolder ()
 
MRMESH_API std::shared_ptr< ObjectgetSharedPtr () const
 
MRMESH_API size_t heapBytes () const
 

Static Public Member Functions

static constexpr const char * TypeName () noexcept
 
- Static Public Member Functions inherited from MR::VisualObject
static constexpr const char * TypeName () noexcept
 
- Static Public Member Functions inherited from MR::Object
static constexpr const char * TypeName () noexcept
 

Public Attributes

SelectionChangedSignal faceSelectionChangedSignal
 
SelectionChangedSignal edgeSelectionChangedSignal
 
SelectionChangedSignal creasesChangedSignal
 
- Public Attributes inherited from MR::Object
XfChangedSignal worldXfChangedSignal
 

Protected Member Functions

 ObjectMeshHolder (const ObjectMeshHolder &other)=default
 
virtual MRMESH_API void swapBase_ (Object &other) override
 swaps this object with other
 
virtual MRMESH_API void swapSignals_ (Object &other) override
 
virtual MRMESH_API Expected< std::future< VoidOrErrStr > > serializeModel_ (const std::filesystem::path &path) const override
 
virtual MRMESH_API void serializeFields_ (Json::Value &root) const override
 
MRMESH_API void deserializeFields_ (const Json::Value &root) override
 
MRMESH_API VoidOrErrStr deserializeModel_ (const std::filesystem::path &path, ProgressCallback progressCb={}) override
 Reads model from file.
 
MRMESH_API void setAllVisualizeProperties_ (const AllVisualizeProperties &properties, std::size_t &pos) override
 set all visualize properties masks
 
virtual MRMESH_API Box3f computeBoundingBox_ () const override
 
virtual MRMESH_API void setupRenderObject_ () const override
 
- Protected Member Functions inherited from MR::VisualObject
 VisualObject (const VisualObject &obj)=default
 
MRMESH_API ViewportMaskgetVisualizePropertyMask_ (AnyVisualizeMaskEnum type)
 
MRMESH_API void deserializeFields_ (const Json::Value &root) override
 
MRMESH_API void boundingBoxToInfoLines_ (std::vector< std::string > &res) const
 adds information about bounding box in res
 
template<AnyVisualizeMaskEnumType T>
void setAllVisualizePropertiesForEnum (const AllVisualizeProperties &properties, std::size_t &pos)
 
template<AnyVisualizeMaskEnumType T>
void getAllVisualizePropertiesForEnum (AllVisualizeProperties &properties) const
 
- Protected Member Functions inherited from MR::Object
 Object (const Object &obj)=default
 user should not be able to call copy implicitly, use clone() function instead
 
virtual MRMESH_API void propagateWorldXfChangedSignal_ ()
 

Protected Attributes

FaceBitSet selectedTriangles_
 
UndirectedEdgeBitSet selectedEdges_
 
UndirectedEdgeBitSet creases_
 
Vector< MeshTexture, TextureId > textures_
 Texture options.
 
VertUVCoords uvCoordinates_
 vertices coordinates in texture
 
Vector< TextureId, FaceIdtexturePerFace_
 
MeshTexture ancillaryTexture_
 
VertUVCoords ancillaryUVCoordinates_
 vertices coordinates in ancillary texture
 
std::optional< size_t > numHoles_
 
std::optional< size_t > numComponents_
 
std::optional< size_t > numUndirectedEdges_
 
std::optional< size_t > numHandles_
 
std::optional< bool > meshIsClosed_
 
std::optional< size_t > numSelectedFaces_
 
std::optional< size_t > numSelectedEdges_
 
std::optional< size_t > numCreaseEdges_
 
std::optional< double > totalArea_
 
std::optional< double > selectedArea_
 
std::optional< double > volume_
 
std::optional< float > avgEdgeLen_
 
ViewportProperty< XfBasedCache< Box3f > > worldBox_
 
ViewportMask showTexture_
 
ViewportMask showFaces_ = ViewportMask::all()
 
ViewportMask showEdges_
 
ViewportMask showPoints_
 
ViewportMask showSelectedEdges_ = ViewportMask::all()
 
ViewportMask showSelectedFaces_ = ViewportMask::all()
 
ViewportMask showBordersHighlight_
 
ViewportMask polygonOffset_
 
ViewportMask flatShading_
 toggle per-face or per-vertex properties
 
ViewportMask shadingEnabled_ = ViewportMask::all()
 
ViewportMask onlyOddFragments_
 
ViewportProperty< ColoredgesColor_
 
ViewportProperty< ColorpointsColor_
 
ViewportProperty< ColorbordersColor_
 
ViewportProperty< ColoredgeSelectionColor_
 
ViewportProperty< ColorfaceSelectionColor_
 
FaceColors facesColorMap_
 
float edgeWidth_ { 0.5f }
 
float pointSize_ { 5.f }
 
std::shared_ptr< Meshmesh_
 
- Protected Attributes inherited from MR::VisualObject
UniquePtr< IRenderObjectrenderObj_
 
Dirty dirty_
 
ViewportMask clipByPlane_
 
ViewportMask showLabels_
 
ViewportMask showName_
 
ViewportMask cropLabels_ = ViewportMask::all()
 
ViewportMask pickable_ = ViewportMask::all()
 enable picking by gl
 
ViewportMask invertNormals_
 invert mesh normals
 
ViewportMask depthTest_ = ViewportMask::all()
 
ViewportProperty< ColorlabelsColor_ = {}
 
float shininess_ {35.0f}
 specular exponent
 
float specularStrength_ { 0.5f }
 
float ambientStrength_ { 0.1f }
 
ColoringType coloringType_ {ColoringType::SolidColor}
 Main coloring options.
 
VertColors vertsColorMap_
 
ViewportProperty< ColorselectedColor_
 
ViewportProperty< ColorunselectedColor_
 
ViewportProperty< ColorbackFacesColor_
 
ViewportProperty< uint8_t > globalAlpha_ { 255 }
 
std::vector< PositionedTextlabels_
 
bool useDefaultScenePropertiesOnDeserialization_ { false }
 
- Protected Attributes inherited from MR::Object
std::string name_
 
ViewportProperty< AffineXf3fxf_
 
ViewportMask visibilityMask_ = ViewportMask::all()
 
bool locked_ = false
 
bool parentLocked_ = false
 
bool selected_ { false }
 
bool ancillary_ { false }
 
bool needRedraw_ {false}
 
- Protected Attributes inherited from MR::ObjectChildrenHolder
ObjectChildrenHolderparent_ = nullptr
 
std::vector< std::shared_ptr< Object > > children_
 
std::vector< std::weak_ptr< Object > > bastards_
 recognized ones
 

Detailed Description

an object that stores a mesh

Member Typedef Documentation

◆ SelectionChangedSignal

signal about face selection changing, triggered in selectFaces

Constructor & Destructor Documentation

◆ ObjectMeshHolder() [1/4]

MRMESH_API MR::ObjectMeshHolder::ObjectMeshHolder ( )

◆ ObjectMeshHolder() [2/4]

MR::ObjectMeshHolder::ObjectMeshHolder ( ObjectMeshHolder && )
defaultnoexcept

◆ ObjectMeshHolder() [3/4]

MR::ObjectMeshHolder::ObjectMeshHolder ( ProtectedStruct ,
const ObjectMeshHolder & obj )
inline
Note
this ctor is public only for std::make_shared used inside clone()

◆ ObjectMeshHolder() [4/4]

MR::ObjectMeshHolder::ObjectMeshHolder ( const ObjectMeshHolder & other)
protecteddefault

Member Function Documentation

◆ addTexture()

virtual void MR::ObjectMeshHolder::addTexture ( MeshTexture texture)
inlinevirtual

◆ applyScale()

virtual MRMESH_API void MR::ObjectMeshHolder::applyScale ( float scaleFactor)
overridevirtual

scale object size (all point positions)

Reimplemented from MR::Object.

Reimplemented in MR::ObjectDistanceMap, and MR::ObjectVoxels.

◆ avgEdgeLen()

MRMESH_API float MR::ObjectMeshHolder::avgEdgeLen ( ) const
nodiscard

returns cached average edge length

◆ clearAncillaryTexture()

MRMESH_API void MR::ObjectMeshHolder::clearAncillaryTexture ( )

◆ clone()

virtual MRMESH_API std::shared_ptr< Object > MR::ObjectMeshHolder::clone ( ) const
overridevirtual

clones this object only, without its children, making new object the owner of all copied resources

Reimplemented from MR::VisualObject.

Reimplemented in MR::ObjectDistanceMap, MR::ObjectMesh, and MR::ObjectVoxels.

◆ computeBoundingBox_()

virtual MRMESH_API Box3f MR::ObjectMeshHolder::computeBoundingBox_ ( ) const
overrideprotectedvirtual

Reimplemented from MR::VisualObject.

◆ copyColors()

MRMESH_API void MR::ObjectMeshHolder::copyColors ( const VisualObject & src,
const VertMap & thisToSrc,
const FaceMap & thisToSrcFaces = {} )
overridevirtual

copies point colors from given source object

Parameters
srcusing given map
thisToSrc

Reimplemented from MR::VisualObject.

◆ copyTextureAndColors()

virtual MRMESH_API void MR::ObjectMeshHolder::copyTextureAndColors ( const ObjectMeshHolder & src,
const VertMap & thisToSrc,
const FaceMap & thisToSrcFaces = {} )
virtual

copies texture, UV-coordinates and vertex colors from given source object

Parameters
srcusing given map
thisToSrc

◆ creases()

const UndirectedEdgeBitSet & MR::ObjectMeshHolder::creases ( ) const
inline

Edges on mesh, that will have sharp visualization even with smooth shading.

◆ deserializeFields_()

MRMESH_API void MR::ObjectMeshHolder::deserializeFields_ ( const Json::Value & root)
overrideprotectedvirtual

Reads parameters from json value

Note
if you override this method, please call Base::deserializeFields_(root) in the beginning

Reimplemented from MR::Object.

Reimplemented in MR::ObjectVoxels.

◆ deserializeModel_()

MRMESH_API VoidOrErrStr MR::ObjectMeshHolder::deserializeModel_ ( const std::filesystem::path & path,
ProgressCallback progressCb = {} )
overrideprotectedvirtual

Reads model from file.

Reimplemented from MR::Object.

Reimplemented in MR::ObjectVoxels.

◆ flatShading()

bool MR::ObjectMeshHolder::flatShading ( ) const
inline

◆ getAllVisualizeProperties()

MRMESH_API AllVisualizeProperties MR::ObjectMeshHolder::getAllVisualizeProperties ( ) const
overridevirtual

get all visualize properties masks

Reimplemented from MR::VisualObject.

◆ getAncillaryTexture()

const MeshTexture & MR::ObjectMeshHolder::getAncillaryTexture ( ) const
inline

◆ getAncillaryUVCoords()

const VertUVCoords & MR::ObjectMeshHolder::getAncillaryUVCoords ( ) const
inline

◆ getBordersColor()

const Color & MR::ObjectMeshHolder::getBordersColor ( ViewportId id = {}) const
inline

◆ getBordersColorsForAllViewports()

MRMESH_API const ViewportProperty< Color > & MR::ObjectMeshHolder::getBordersColorsForAllViewports ( ) const

◆ getEdgesColor()

const Color & MR::ObjectMeshHolder::getEdgesColor ( ViewportId id = {}) const
inline

◆ getEdgesColorsForAllViewports()

MRMESH_API const ViewportProperty< Color > & MR::ObjectMeshHolder::getEdgesColorsForAllViewports ( ) const

◆ getEdgeWidth()

float MR::ObjectMeshHolder::getEdgeWidth ( ) const
inline

◆ getFacesColorMap()

const FaceColors & MR::ObjectMeshHolder::getFacesColorMap ( ) const
inline

◆ getNeededNormalsRenderDirtyValue()

MRMESH_API uint32_t MR::ObjectMeshHolder::getNeededNormalsRenderDirtyValue ( ViewportMask viewportMask) const

returns dirty flag of currently using normal type if they are dirty in render representation

◆ getPointsColor()

const Color & MR::ObjectMeshHolder::getPointsColor ( ViewportId id = {}) const
inline

◆ getPointSize()

virtual float MR::ObjectMeshHolder::getPointSize ( ) const
inlinevirtual

◆ getRedrawFlag()

virtual MRMESH_API bool MR::ObjectMeshHolder::getRedrawFlag ( ViewportMask viewportMask) const
overridevirtual

returns true if the object must be redrawn (due to dirty flags) in one of specified viewports

Reimplemented from MR::VisualObject.

◆ getSelectedEdges()

const UndirectedEdgeBitSet & MR::ObjectMeshHolder::getSelectedEdges ( ) const
inline

◆ getSelectedEdgesColor()

MRMESH_API const Color & MR::ObjectMeshHolder::getSelectedEdgesColor ( ViewportId id = {}) const

returns colors of selected edges

◆ getSelectedEdgesColorsForAllViewports()

MRMESH_API const ViewportProperty< Color > & MR::ObjectMeshHolder::getSelectedEdgesColorsForAllViewports ( ) const

◆ getSelectedFaces()

const FaceBitSet & MR::ObjectMeshHolder::getSelectedFaces ( ) const
inline

◆ getSelectedFacesColor()

MRMESH_API const Color & MR::ObjectMeshHolder::getSelectedFacesColor ( ViewportId id = {}) const

returns colors of selected triangles

◆ getSelectedFacesColorsForAllViewports()

MRMESH_API const ViewportProperty< Color > & MR::ObjectMeshHolder::getSelectedFacesColorsForAllViewports ( ) const

◆ getTexture()

MRMESH_API const MeshTexture & MR::ObjectMeshHolder::getTexture ( ) const

returns first texture in the vector. If there is no textures, returns empty texture

◆ getTexturePerFace()

const TexturePerFace & MR::ObjectMeshHolder::getTexturePerFace ( ) const
inline

◆ getTextures()

const Vector< MeshTexture, TextureId > & MR::ObjectMeshHolder::getTextures ( ) const
inline

◆ getUVCoords()

const VertUVCoords & MR::ObjectMeshHolder::getUVCoords ( ) const
inline

◆ getVisualizePropertyMask()

MRMESH_API const ViewportMask & MR::ObjectMeshHolder::getVisualizePropertyMask ( AnyVisualizeMaskEnum type) const
overridevirtual

returns mask of viewports where given property is set

Reimplemented from MR::VisualObject.

◆ getWorldBox()

virtual MRMESH_API Box3f MR::ObjectMeshHolder::getWorldBox ( ViewportId = {}) const
nodiscardoverridevirtual

returns cached bounding box of this mesh object in world coordinates; if you need bounding box in local coordinates please call getBoundingBox()

Reimplemented from MR::VisualObject.

◆ hasAncillaryTexture()

bool MR::ObjectMeshHolder::hasAncillaryTexture ( ) const
inline

◆ hasModel()

virtual bool MR::ObjectMeshHolder::hasModel ( ) const
inlinenodiscardoverridevirtual

does the object have any model available (but possibly empty), e.g. ObjectMesh has valid mesh() or ObjectPoints has valid pointCloud()

Reimplemented from MR::Object.

Reimplemented in MR::ObjectDistanceMap, and MR::ObjectVoxels.

◆ hasVisualRepresentation()

virtual MRMESH_API bool MR::ObjectMeshHolder::hasVisualRepresentation ( ) const
overridevirtual

mesh object can be seen if the mesh has at least one edge

Reimplemented from MR::Object.

Reimplemented in MR::ObjectVoxels.

◆ heapBytes()

virtual MRMESH_API size_t MR::ObjectMeshHolder::heapBytes ( ) const
nodiscardoverridevirtual

returns the amount of memory this object occupies on heap

Reimplemented from MR::VisualObject.

Reimplemented in MR::ObjectDistanceMap, and MR::ObjectVoxels.

◆ isMeshClosed()

MRMESH_API bool MR::ObjectMeshHolder::isMeshClosed ( ) const
nodiscard

returns cached information whether the mesh is closed

◆ mesh()

const std::shared_ptr< const Mesh > & MR::ObjectMeshHolder::mesh ( ) const
inline

◆ meshPart()

MeshPart MR::ObjectMeshHolder::meshPart ( ) const
inline
Returns
the pair ( mesh, selected triangles ) if any triangle is selected or whole mesh otherwise

◆ numComponents()

MRMESH_API size_t MR::ObjectMeshHolder::numComponents ( ) const
nodiscard

returns cached information about the number of components in the mesh

◆ numCreaseEdges()

MRMESH_API size_t MR::ObjectMeshHolder::numCreaseEdges ( ) const
nodiscard

returns cached information about the number of crease undirected edges in the mesh

◆ numHandles()

MRMESH_API size_t MR::ObjectMeshHolder::numHandles ( ) const
nodiscard

returns cached information about the number of handles in the mesh

◆ numHoles()

MRMESH_API size_t MR::ObjectMeshHolder::numHoles ( ) const
nodiscard

returns cached information about the number of holes in the mesh

◆ numSelectedEdges()

MRMESH_API size_t MR::ObjectMeshHolder::numSelectedEdges ( ) const
nodiscard

returns cached information about the number of selected undirected edges in the mesh

◆ numSelectedFaces()

MRMESH_API size_t MR::ObjectMeshHolder::numSelectedFaces ( ) const
nodiscard

returns cached information about the number of selected faces in the mesh

◆ numUndirectedEdges()

MRMESH_API size_t MR::ObjectMeshHolder::numUndirectedEdges ( ) const
nodiscard

returns cached information about the number of undirected edges in the mesh

◆ operator=()

ObjectMeshHolder & MR::ObjectMeshHolder::operator= ( ObjectMeshHolder && )
defaultnoexcept

◆ resetDirtyExeptMask()

virtual MRMESH_API void MR::ObjectMeshHolder::resetDirtyExeptMask ( uint32_t mask) const
virtual

reset dirty flags without some specific bits (useful for lazy normals update)

◆ saveMeshFormat()

const char * MR::ObjectMeshHolder::saveMeshFormat ( ) const
inlinenodiscard

returns file extension used to serialize the mesh

◆ selectedArea()

MRMESH_API double MR::ObjectMeshHolder::selectedArea ( ) const
nodiscard

returns cached area of selected triangles

◆ selectEdges()

virtual MRMESH_API void MR::ObjectMeshHolder::selectEdges ( UndirectedEdgeBitSet newSelection)
virtual

◆ selectFaces()

virtual MRMESH_API void MR::ObjectMeshHolder::selectFaces ( FaceBitSet newSelection)
virtual

◆ serializeFields_()

virtual MRMESH_API void MR::ObjectMeshHolder::serializeFields_ ( Json::Value & root) const
overrideprotectedvirtual

Write parameters to given Json::Value,

Note
if you override this method, please call Base::serializeFields_(root) in the beginning

Reimplemented from MR::VisualObject.

Reimplemented in MR::ObjectDistanceMap, MR::ObjectMesh, and MR::ObjectVoxels.

◆ serializeModel_()

virtual MRMESH_API Expected< std::future< VoidOrErrStr > > MR::ObjectMeshHolder::serializeModel_ ( const std::filesystem::path & path) const
overrideprotectedvirtual

Creates future to save object model (e.g. mesh) in given file path is full filename without extension

Reimplemented from MR::Object.

Reimplemented in MR::ObjectDistanceMap, and MR::ObjectVoxels.

◆ setAllVisualizeProperties_()

MRMESH_API void MR::ObjectMeshHolder::setAllVisualizeProperties_ ( const AllVisualizeProperties & properties,
std::size_t & pos )
overrideprotectedvirtual

set all visualize properties masks

Reimplemented from MR::VisualObject.

◆ setAncillaryTexture()

virtual void MR::ObjectMeshHolder::setAncillaryTexture ( MeshTexture texture)
inlinevirtual

◆ setAncillaryUVCoords()

virtual void MR::ObjectMeshHolder::setAncillaryUVCoords ( VertUVCoords uvCoordinates)
inlinevirtual

◆ setBordersColor()

virtual void MR::ObjectMeshHolder::setBordersColor ( const Color & color,
ViewportId id = {} )
inlinevirtual

◆ setBordersColorsForAllViewports()

virtual MRMESH_API void MR::ObjectMeshHolder::setBordersColorsForAllViewports ( ViewportProperty< Color > val)
virtual

◆ setCreases()

virtual MRMESH_API void MR::ObjectMeshHolder::setCreases ( UndirectedEdgeBitSet creases)
virtual

◆ setDirtyFlags()

virtual MRMESH_API void MR::ObjectMeshHolder::setDirtyFlags ( uint32_t mask,
bool invalidateCaches = true )
overridevirtual

sets some dirty flags for the object (to force its visual update)

Parameters
maskis a union of DirtyFlags flags
invalidateCacheswhether to automatically invalidate model caches (pass false here if you manually update the caches)

Reimplemented from MR::VisualObject.

Reimplemented in MR::ObjectMesh, and MR::ObjectVoxels.

◆ setEdgesColor()

virtual void MR::ObjectMeshHolder::setEdgesColor ( const Color & color,
ViewportId id = {} )
inlinevirtual

◆ setEdgesColorsForAllViewports()

virtual MRMESH_API void MR::ObjectMeshHolder::setEdgesColorsForAllViewports ( ViewportProperty< Color > val)
virtual

◆ setEdgeWidth()

virtual MRMESH_API void MR::ObjectMeshHolder::setEdgeWidth ( float edgeWidth)
virtual

◆ setFacesColorMap()

virtual void MR::ObjectMeshHolder::setFacesColorMap ( FaceColors facesColorMap)
inlinevirtual

◆ setFlatShading()

void MR::ObjectMeshHolder::setFlatShading ( bool on)
inline

sets flat (true) or smooth (false) shading

◆ setPointsColor()

virtual void MR::ObjectMeshHolder::setPointsColor ( const Color & color,
ViewportId id = {} )
inlinevirtual

◆ setPointSize()

virtual MRMESH_API void MR::ObjectMeshHolder::setPointSize ( float size)
virtual

◆ setSaveMeshFormat()

MRMESH_API void MR::ObjectMeshHolder::setSaveMeshFormat ( const char * newFormat)

sets file extension used to serialize the mesh: must be not null and must start from '.'

◆ setSelectedEdgesColor()

virtual MRMESH_API void MR::ObjectMeshHolder::setSelectedEdgesColor ( const Color & color,
ViewportId id = {} )
virtual

sets colors of selected edges

◆ setSelectedEdgesColorsForAllViewports()

virtual MRMESH_API void MR::ObjectMeshHolder::setSelectedEdgesColorsForAllViewports ( ViewportProperty< Color > val)
virtual

◆ setSelectedFacesColor()

virtual MRMESH_API void MR::ObjectMeshHolder::setSelectedFacesColor ( const Color & color,
ViewportId id = {} )
virtual

sets colors of selected triangles

◆ setSelectedFacesColorsForAllViewports()

virtual MRMESH_API void MR::ObjectMeshHolder::setSelectedFacesColorsForAllViewports ( ViewportProperty< Color > val)
virtual

◆ setTexture()

virtual MRMESH_API void MR::ObjectMeshHolder::setTexture ( MeshTexture texture)
virtual

◆ setTexturePerFace()

virtual void MR::ObjectMeshHolder::setTexturePerFace ( Vector< TextureId, FaceId > texturePerFace)
inlinevirtual

the texture ids for the faces if more than one texture is used to texture the object texture coordinates (uvCoordinates_) at a point can belong to different textures, depending on which face the point belongs to

◆ setTextures()

virtual void MR::ObjectMeshHolder::setTextures ( Vector< MeshTexture, TextureId > texture)
inlinevirtual

◆ setupRenderObject_()

virtual MRMESH_API void MR::ObjectMeshHolder::setupRenderObject_ ( ) const
overrideprotectedvirtual

each renderable child of VisualObject should implement this method and assign renderObj_ inside

Reimplemented from MR::VisualObject.

◆ setUVCoords()

virtual void MR::ObjectMeshHolder::setUVCoords ( VertUVCoords uvCoordinates)
inlinevirtual

◆ shallowClone()

virtual MRMESH_API std::shared_ptr< Object > MR::ObjectMeshHolder::shallowClone ( ) const
overridevirtual

clones this object only, without its children, making new object to share resources with this object

Reimplemented from MR::VisualObject.

Reimplemented in MR::ObjectDistanceMap, MR::ObjectMesh, and MR::ObjectVoxels.

◆ supportsVisualizeProperty()

MRMESH_API bool MR::ObjectMeshHolder::supportsVisualizeProperty ( AnyVisualizeMaskEnum type) const
nodiscardoverridevirtual

Returns true if this class supports the property type. Otherwise passing it to the functions below is illegal.

Reimplemented from MR::VisualObject.

◆ swapBase_()

virtual MRMESH_API void MR::ObjectMeshHolder::swapBase_ ( Object & other)
overrideprotectedvirtual

swaps this object with other

Reimplemented from MR::VisualObject.

Reimplemented in MR::ObjectDistanceMap, MR::ObjectMesh, and MR::ObjectVoxels.

◆ swapSignals_()

virtual MRMESH_API void MR::ObjectMeshHolder::swapSignals_ ( Object & other)
overrideprotectedvirtual

swaps signals, used in swap function to return back signals after swapBase_ pls call Parent::swapSignals_ first when overriding this function

Reimplemented from MR::Object.

Reimplemented in MR::ObjectMesh, and MR::ObjectVoxels.

◆ totalArea()

MRMESH_API double MR::ObjectMeshHolder::totalArea ( ) const
nodiscard

returns cached summed area of mesh triangles

◆ TypeName()

static constexpr const char * MR::ObjectMeshHolder::TypeName ( )
inlinestaticconstexprnoexcept

◆ typeName()

virtual const char * MR::ObjectMeshHolder::typeName ( ) const
inlineoverridevirtual

Reimplemented from MR::VisualObject.

Reimplemented in MR::ObjectDistanceMap, MR::ObjectMesh, and MR::ObjectVoxels.

◆ updateAncillaryUVCoords()

void MR::ObjectMeshHolder::updateAncillaryUVCoords ( VertUVCoords & updated)
inline

◆ updateFacesColorMap()

virtual void MR::ObjectMeshHolder::updateFacesColorMap ( FaceColors & updated)
inlinevirtual

◆ updateTexture()

virtual MRMESH_API void MR::ObjectMeshHolder::updateTexture ( MeshTexture & updated)
virtual

◆ updateTexturePerFace()

virtual void MR::ObjectMeshHolder::updateTexturePerFace ( Vector< TextureId, FaceId > & texturePerFace)
inlinevirtual

◆ updateTextures()

virtual void MR::ObjectMeshHolder::updateTextures ( Vector< MeshTexture, TextureId > & updated)
inlinevirtual

◆ updateUVCoords()

virtual void MR::ObjectMeshHolder::updateUVCoords ( VertUVCoords & updated)
inlinevirtual

◆ volume()

MRMESH_API double MR::ObjectMeshHolder::volume ( ) const
nodiscard

returns cached volume of space surrounded by the mesh, which is valid only if mesh is closed

Member Data Documentation

◆ ancillaryTexture_

MeshTexture MR::ObjectMeshHolder::ancillaryTexture_
protected

◆ ancillaryUVCoordinates_

VertUVCoords MR::ObjectMeshHolder::ancillaryUVCoordinates_
protected

vertices coordinates in ancillary texture

◆ avgEdgeLen_

std::optional<float> MR::ObjectMeshHolder::avgEdgeLen_
mutableprotected

◆ bordersColor_

ViewportProperty<Color> MR::ObjectMeshHolder::bordersColor_
protected

◆ creases_

UndirectedEdgeBitSet MR::ObjectMeshHolder::creases_
protected

◆ creasesChangedSignal

SelectionChangedSignal MR::ObjectMeshHolder::creasesChangedSignal

◆ edgesColor_

ViewportProperty<Color> MR::ObjectMeshHolder::edgesColor_
protected

◆ edgeSelectionChangedSignal

SelectionChangedSignal MR::ObjectMeshHolder::edgeSelectionChangedSignal

◆ edgeSelectionColor_

ViewportProperty<Color> MR::ObjectMeshHolder::edgeSelectionColor_
protected

◆ edgeWidth_

float MR::ObjectMeshHolder::edgeWidth_ { 0.5f }
protected

◆ facesColorMap_

FaceColors MR::ObjectMeshHolder::facesColorMap_
protected

◆ faceSelectionChangedSignal

SelectionChangedSignal MR::ObjectMeshHolder::faceSelectionChangedSignal

◆ faceSelectionColor_

ViewportProperty<Color> MR::ObjectMeshHolder::faceSelectionColor_
protected

◆ flatShading_

ViewportMask MR::ObjectMeshHolder::flatShading_
protected

toggle per-face or per-vertex properties

◆ mesh_

std::shared_ptr<Mesh> MR::ObjectMeshHolder::mesh_
protected

◆ meshIsClosed_

std::optional<bool> MR::ObjectMeshHolder::meshIsClosed_
mutableprotected

◆ numComponents_

std::optional<size_t> MR::ObjectMeshHolder::numComponents_
mutableprotected

◆ numCreaseEdges_

std::optional<size_t> MR::ObjectMeshHolder::numCreaseEdges_
protected

◆ numHandles_

std::optional<size_t> MR::ObjectMeshHolder::numHandles_
mutableprotected

◆ numHoles_

std::optional<size_t> MR::ObjectMeshHolder::numHoles_
mutableprotected

◆ numSelectedEdges_

std::optional<size_t> MR::ObjectMeshHolder::numSelectedEdges_
protected

◆ numSelectedFaces_

std::optional<size_t> MR::ObjectMeshHolder::numSelectedFaces_
mutableprotected

◆ numUndirectedEdges_

std::optional<size_t> MR::ObjectMeshHolder::numUndirectedEdges_
mutableprotected

◆ onlyOddFragments_

ViewportMask MR::ObjectMeshHolder::onlyOddFragments_
protected

◆ pointsColor_

ViewportProperty<Color> MR::ObjectMeshHolder::pointsColor_
protected

◆ pointSize_

float MR::ObjectMeshHolder::pointSize_ { 5.f }
protected

◆ polygonOffset_

ViewportMask MR::ObjectMeshHolder::polygonOffset_
protected

◆ selectedArea_

std::optional<double> MR::ObjectMeshHolder::selectedArea_
protected

◆ selectedEdges_

UndirectedEdgeBitSet MR::ObjectMeshHolder::selectedEdges_
protected

◆ selectedTriangles_

FaceBitSet MR::ObjectMeshHolder::selectedTriangles_
protected

◆ shadingEnabled_

ViewportMask MR::ObjectMeshHolder::shadingEnabled_ = ViewportMask::all()
protected

◆ showBordersHighlight_

ViewportMask MR::ObjectMeshHolder::showBordersHighlight_
protected

◆ showEdges_

ViewportMask MR::ObjectMeshHolder::showEdges_
protected

◆ showFaces_

ViewportMask MR::ObjectMeshHolder::showFaces_ = ViewportMask::all()
protected

◆ showPoints_

ViewportMask MR::ObjectMeshHolder::showPoints_
protected

◆ showSelectedEdges_

ViewportMask MR::ObjectMeshHolder::showSelectedEdges_ = ViewportMask::all()
protected

◆ showSelectedFaces_

ViewportMask MR::ObjectMeshHolder::showSelectedFaces_ = ViewportMask::all()
protected

◆ showTexture_

ViewportMask MR::ObjectMeshHolder::showTexture_
protected

◆ texturePerFace_

Vector<TextureId, FaceId> MR::ObjectMeshHolder::texturePerFace_
protected

◆ textures_

Vector<MeshTexture, TextureId> MR::ObjectMeshHolder::textures_
protected

Texture options.

◆ totalArea_

std::optional<double> MR::ObjectMeshHolder::totalArea_
mutableprotected

◆ uvCoordinates_

VertUVCoords MR::ObjectMeshHolder::uvCoordinates_
protected

vertices coordinates in texture

◆ volume_

std::optional<double> MR::ObjectMeshHolder::volume_
mutableprotected

◆ worldBox_

ViewportProperty<XfBasedCache<Box3f> > MR::ObjectMeshHolder::worldBox_
mutableprotected

The documentation for this class was generated from the following file: