Subversion Repositories gelsvn

Rev

Rev 630 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
595 jab 1
/* ----------------------------------------------------------------------- *
2
 * This file is part of GEL, http://www.imm.dtu.dk/GEL
3
 * Copyright (C) the authors and DTU Informatics
4
 * For license and list of authors, see ../../doc/intro.pdf
5
 * ----------------------------------------------------------------------- */
6
 
7
/**
8
 * @file caps_and_needles.h
9
 * @brief Simple tools for improving polygonal meshes by removing bad triangles.
10
 */
11
 
448 jab 12
#ifndef __HMESH_CAPS_AND_NEEDLES_H__
13
#define __HMESH_CAPS_AND_NEEDLES_H__
149 jab 14
 
150 jab 15
namespace HMesh
149 jab 16
{
595 jab 17
    class Manifold;
18
    /** \brief Remove caps from a manifold consisting of only triangles.
19
    A cap is a triangle with two very small angles and an angle close to pi, however a cap does not necessarily have a very short edge.
20
    Set the ang_thresh to a value close to pi. The closer to pi the _less_ sensitive the cap removal.
21
    A cap is removed by flipping the (long) edge E opposite to the vertex V with the angle close to pi. 
22
    However, the function is more complex. Read code and document more carefully !!! */
23
    void remove_caps(Manifold& m, float thresh);
149 jab 24
 
595 jab 25
    /** \brief Remove needles from a manifold consisting of only triangles.
26
    A needle is a triangle with a single very short edge. It is moved by collapsing the short edge. 
27
    The thresh parameter sets the length threshold.		
28
    The position of the vertex which survives the collapse is set to one of the two end points. 
29
    Selection is based on what changes the geometry least. */
30
    void remove_needles(Manifold& m, float thresh);
600 jab 31
 
32
    /** \brief Stitch together edges whose endpoints coincide geometrically. 
33
     This function allows you to create a mesh as a bunch of faces and then stitch these together
34
     to form a coherent whole. What this function adds is a spatial data structure to find out
35
     which vertices coincide. The return value is the number of edges that could not be stitched. 
36
     Often this is because it would introduce a non-manifold situation.*/
666 janba 37
    int stitch_mesh(Manifold& m, double rad);
600 jab 38
 
39
    /** \brief Stitches the mesh together, splits edges that could not be stitched and goes again.
40
     This function thereby handles situations where stitch mesh would not have worked. */
666 janba 41
    void stitch_more(Manifold& m, double rad);
600 jab 42
 
43
    /** \brief This function replaces holes by faces.
44
     It is really a simple function that just finds all loops of edges next to missing faces. */
45
    void close_holes(Manifold& m);
46
 
666 janba 47
    /** \brief Flip the orientation of a mesh.
48
     After calling this function, normals will point the other way and clockwise becomes 
49
     counter clockwise */
50
    void flip_orientation(Manifold& m);
51
 
52
    /** Remove valence two vertices. */
53
    void remove_valence_two_vertices(Manifold & m);
54
 
55
 
149 jab 56
}
57
 
595 jab 58
#endif