#include <MRMeshC/MRBitSet.h>
#include <MRMeshC/MRMesh.h>
#include <MRMeshC/MRMeshFillHole.h>
#include <MRMeshC/MRMeshLoad.h>
#include <MRMeshC/MRMeshSave.h>
#include <MRMeshC/MRMeshTopology.h>
#include <MRMeshC/MRString.h>
#include <stdio.h>
#include <stdlib.h>
#define MIN_HOLE_AREA 100.f
int main( int argc, char* argv[] )
{
int rc = EXIT_FAILURE;
if ( argc != 2 && argc != 3 )
{
fprintf( stderr, "Usage: %s INPUT [OUTPUT]", argv[0] );
goto out;
}
const char* input = argv[1];
const char* output = ( argc == 2 ) ? argv[1] : argv[2];
if ( errorString )
{
fprintf( stderr,
"Failed to load mesh: %s",
mrStringData( errorString ) );
goto out;
}
if ( holes->size == 0 )
{
printf( "Mesh doesn't have any holes" );
goto out_holes;
}
size_t newFaceCount = 0;
#define FILL_ALL_HOLES 1
#if FILL_ALL_HOLES
mrFillHoles( mesh, holes->data, holes->size, ¶ms );
#else
for ( int i = 0; i < mrEdgePathSize( holes ); i++ )
{
MREdgeId e = mrEdgePathData( holes )[i];
if ( mrVector3Length( &holeDirArea ) >= MIN_HOLE_AREA )
{
}
}
#endif
printf( "Added new %zu faces", newFaceCount );
if ( errorString )
{
fprintf( stderr,
"Failed to save mesh: %s",
mrStringData( errorString ) );
goto out_newFaces;
}
rc = EXIT_SUCCESS;
out_newFaces:
out_metric:
out_holes:
mrEdgePathFree( holes );
out_mesh:
out:
return rc;
}
MRMESHC_API size_t mrBitSetCount(const MRBitSet *bs)
MRMESHC_API void mrFaceBitSetFree(MRFaceBitSet *fbs)
MRMESHC_API MRFaceBitSet * mrFaceBitSetNew(size_t numBits, bool fillValue)
MRMESHC_API void mrFillHole(MRMesh *mesh, MREdgeId a, const MRFillHoleParams *params)
MRMESHC_API void mrFillHoles(MRMesh *mesh, const MREdgeId *as, size_t asNum, const MRFillHoleParams *params)
MRMESHC_API MRFillHoleParams mrFillHoleParamsNew(void)
struct MRFaceBitSet MRFaceBitSet
typedefMR_EXTERN_C_BEGIN struct MRString MRString
MRMESHC_API MRFillHoleMetric * mrGetUniversalMetric(const MRMesh *mesh)
MRMESHC_API void mrFillHoleMetricFree(MRFillHoleMetric *metric)
MRMESHC_API MRVector3f mrMeshHoleDirArea(const MRMesh *mesh, MREdgeId e)
MRMESHC_API MREdgePath * mrMeshFindHoleRepresentiveEdges(const MRMesh *mesh)
MRMESHC_API void mrMeshFree(MRMesh *mesh)
MRMESHC_API MRSaveSettings mrSaveSettingsNew(void)
MRMESHC_API void mrStringFree(MRString *str)
MR_EXTERN_C_BEGIN MRMESHC_API const char * mrStringData(const MRString *str)
MRMESHC_API MRMesh * mrMeshLoadFromAnySupportedFormat(const char *file, MRString **errorStr)
MRMESHC_API void mrMeshSaveToAnySupportedFormat(const MRMesh *mesh, const char *file, MRString **errorStr)
MRFaceBitSet * outNewFaces
const MRFillHoleMetric * metric