MNChamferData Class Reference

MNChamferData Class Reference

#include <mnmesh.h>

Class Description

Contains all the data needed to move points (and map vertices) as the user drags a chamfer or extrude.

It's created by the topological change that happens at the start of the chamfer or extrude. The strategy is this: The chamfer/extrude operation is divided into two parts, the topological change and a later geometric change. (This works well for Editable Poly, where the topology change is completed first, then apply a series of geometry changes as the user spins a spinner or drags a mouse. Each geometry change is undone before the next is applied, but the topology change only happens once.)

This class is first initialized to a mesh. Then its data is filled in by the topological change. This data is used to find "directions" for all the geometric and mapping vert changes over the course of the geometric modification.

Note
For convenient caching, it is recommended that you use this class through the MNTempData class.
See also
MNTempData, MNMesh
+ Inheritance diagram for MNChamferData:

Public Member Functions

 MNChamferData ()
 Constructor. More...
 
 MNChamferData (const MNMesh &m)
 Constructor. More...
 
DllExport ~MNChamferData ()
 Destructor. More...
 
DllExport void InitToMesh (const MNMesh &m)
 This method sets up the MNChamferData based on a given mesh, allocating the vertex and mapping vertex tables as appropriate. More...
 
DllExport void setNumVerts (int nv, bool keep=TRUE, int resizer=0)
 This method allocates the vdir and vmax tables, and initializes the new members of vmax to 0. More...
 
DllExport void ClearLimits ()
 Clears all the vmax limits to -1 (no limit). More...
 
DllExport void GetDelta (float amount, Tab< Point3 > &delta)
 Uses vectors and limits to obtain the offsets corresponding to a certain extrude or chamfer amount. More...
 
DllExport bool GetMapDelta (MNMesh &mm, int mapChannel, float amount, Tab< UVVert > &delta)
 Uses map vectors and limits to obtain the mapping offsets corresponding to a certain extrude or chamfer amount. More...
 
Tab< UVVert > & MDir (int mapChannel)
 Data accessor. More...
 

Public Attributes

Tab< Point3vdir
 The related direction vectors for mapping vertices in all active mapping channels. More...
 
Tab< float > vmax
 The maximum amount each vector may be applied (before vertices start crossing over each other. More...
 
Tab< UVVert > * mdir
 The related direction vectors for mapping vertices in all active mapping channels. More...
 

Additional Inherited Members

- Static Public Member Functions inherited from MaxHeapOperators
static UtilExport voidoperator new (size_t size)
 Standard new operator used to allocate objects If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, const std::nothrow_t &e)
 Standard new operator used to allocate objects if there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new (size_t size, const char *filename, int line)
 New operator used to allocate objects that takes the filename and line number where the new was called If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, int block_type, const char *filename, int line)
 New operator used to allocate objects that takes the type of memory, filename and line number where the new was called If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, const std::nothrow_t &e, const char *filename, int line)
 New operator used to allocate objects that takes the filename and line number where the new was called If there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new (size_t size, unsigned long flags)
 New operator used to allocate objects that takes extra flags to specify special operations If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, const std::nothrow_t &e, unsigned long flags)
 New operator used to allocate objects that takes extra flags to specify special operations If there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new[] (size_t size)
 New operator used to allocate arrays of objects If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new[] (size_t size, const std::nothrow_t &e)
 New operator used to allocate arrays of objects If there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new[] (size_t size, const char *filename, int line)
 New operator used to allocate arrays of objects If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new[] (size_t size, int block_type, const char *filename, int line)
 New operator used to allocate arrays of objects. More...
 
static UtilExport voidoperator new[] (size_t size, const std::nothrow_t &e, const char *filename, int line)
 New operator used to allocate arrays of objects If there is insufficient memory, NULL will be returned. More...
 
static UtilExport voidoperator new[] (size_t size, unsigned long flags)
 New operator used to allocate arrays of objects If there is insufficient memory, an exception will be thrown. More...
 
static UtilExport voidoperator new[] (size_t size, const std::nothrow_t &e, unsigned long flags)
 New operator used to allocate arrays of objects If there is insufficient memory, NULL will be returned. More...
 
static UtilExport void operator delete (void *ptr)
 Standard delete operator used to deallocate an object If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete (void *ptr, const std::nothrow_t &e)
 Standard delete operator used to deallocate an object If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete (void *ptr, const char *filename, int line)
 Delete operator used to deallocate an object that takes the filename and line number where the delete was called If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete (void *ptr, int block_type, const char *filename, int line)
 Delete operator used to deallocate an object that takes the type of memory, filename and line number where the delete was called If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete (void *ptr, const std::nothrow_t &e, const char *filename, int line)
 Delete operator used to deallocate an object that takes the filename and line number where the delete was called If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete (void *ptr, unsigned long flags)
 Delete operator used to deallocate an object that takes extra flags to specify special operations If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete (void *ptr, const std::nothrow_t &e, unsigned long flags)
 Delete operator used to deallocate an object that takes extra flags to specify special operations If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete[] (void *ptr)
 Standard delete operator used to deallocate an array of objects If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete[] (void *ptr, const std::nothrow_t &e)
 Standard delete operator used to deallocate an array of objects If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete[] (void *ptr, const char *filename, int line)
 Delete operator used to deallocate an array of objects that takes the filename and line number where the delete was called If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete[] (void *ptr, int block_type, const char *filename, int line)
 Delete operator used to deallocate an array of objects that takes the type of memory, filename and line number where the delete was called If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete[] (void *ptr, const std::nothrow_t &e, const char *filename, int line)
 Delete operator used to deallocate an array of objects that takes the filename and line number where the delete was called If the pointer is invalid, nothing will happen. More...
 
static UtilExport void operator delete[] (void *ptr, unsigned long flags)
 Delete operator used to deallocate an array of objects that takes extra flags to specify special operations If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport void operator delete[] (void *ptr, const std::nothrow_t &e, unsigned long flags)
 Delete operator used to deallocate an array of objects that takes extra flags to specify special operations If the pointer is invalid, an exception will be thrown. More...
 
static UtilExport voidoperator new (size_t size, void *placement_ptr)
 Placement new operator. More...
 
static UtilExport void operator delete (void *ptr, void *placement_ptr)
 Placement delete operator. More...
 

Constructor & Destructor Documentation

MNChamferData ( )
inline

Constructor.

5401 { mdir=NULL;}
#define NULL
Definition: autoptr.h:20
Tab< UVVert > * mdir
The related direction vectors for mapping vertices in all active mapping channels.
Definition: mnmesh.h:5398
MNChamferData ( const MNMesh m)
inline

Constructor.

This constructor Initializes to the mesh passed (allocates mapping channels, etc.)

Parameters:
const MNMesh & m

The specified mesh.
5409 { mdir=NULL; InitToMesh(m);}
DllExport void InitToMesh(const MNMesh &m)
This method sets up the MNChamferData based on a given mesh, allocating the vertex and mapping vertex...
#define NULL
Definition: autoptr.h:20
Tab< UVVert > * mdir
The related direction vectors for mapping vertices in all active mapping channels.
Definition: mnmesh.h:5398

Destructor.

Member Function Documentation

DllExport void InitToMesh ( const MNMesh m)

This method sets up the MNChamferData based on a given mesh, allocating the vertex and mapping vertex tables as appropriate.

Parameters:
const MNMesh & m

The Mesh to initialize from.
DllExport void setNumVerts ( int  nv,
bool  keep = TRUE,
int  resizer = 0 
)

This method allocates the vdir and vmax tables, and initializes the new members of vmax to 0.

(Note: this method can be applied to an existing MNChamferData to reflect an increase in vertices in the MNMesh as topological changes occur.)

Parameters:
int nv

The number of vertices.

bool keep=TRUE

TRUE to keep old data if resized; FALSE to discard old data.

int resizer=0

The number of extra elements the vdir and vmax tables are resized beyond their current size. (Extra allocation space to prevent excessive reallocation.)
DllExport void ClearLimits ( )

Clears all the vmax limits to -1 (no limit).

DllExport void GetDelta ( float  amount,
Tab< Point3 > &  delta 
)

Uses vectors and limits to obtain the offsets corresponding to a certain extrude or chamfer amount.

Parameters:
float amount

The amount of the extrude or chamfer.

Tab<Point3> & delta

A table (with size set equal to the number of vertices, aka vdir.Count()) containing the geometric offset for each vertex in the mesh.
DllExport bool GetMapDelta ( MNMesh mm,
int  mapChannel,
float  amount,
Tab< UVVert > &  delta 
)

Uses map vectors and limits to obtain the mapping offsets corresponding to a certain extrude or chamfer amount.

Parameters:
MNMesh & mm

The mesh this MNChamferData is based on.

int mapChannel

The index of the map channel (from -NUM_HIDDENMAPS to mm.MNum()).

float amount

The amount of the extrude or chamfer.

Tab<UVVert> & delta

The offsets for each mapping vertex in this map in the mesh.
Tab<UVVert>& MDir ( int  mapChannel)
inline

Data accessor.

This method returns the appropriate map info. If mp >= 0, it returns the member of the mdir array. If mp < 0, it returns the member of the hmdir array (in keeping with "hidden map channel" indexing conventions).

5468 { return (mapChannel<0) ? hmdir[-1-mapChannel] : mdir[mapChannel]; }
Tab< UVVert > * mdir
The related direction vectors for mapping vertices in all active mapping channels.
Definition: mnmesh.h:5398

Member Data Documentation

Tab<Point3> vdir

The related direction vectors for mapping vertices in all active mapping channels.

Tab<float> vmax

The maximum amount each vector may be applied (before vertices start crossing over each other.

Tab<UVVert>* mdir

The related direction vectors for mapping vertices in all active mapping channels.