BaseEntities.hh 5.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
/*===========================================================================*\
 *                                                                           *
 *                            OpenVolumeMesh                                 *
 *        Copyright (C) 2011 by Computer Graphics Group, RWTH Aachen         *
 *                        www.openvolumemesh.org                             *
 *                                                                           *
 *---------------------------------------------------------------------------*
 *  This file is part of OpenVolumeMesh.                                     *
 *                                                                           *
 *  OpenVolumeMesh is free software: you can redistribute it and/or modify   *
 *  it under the terms of the GNU Lesser General Public License as           *
 *  published by the Free Software Foundation, either version 3 of           *
 *  the License, or (at your option) any later version with the              *
 *  following exceptions:                                                    *
 *                                                                           *
 *  If other files instantiate templates or use macros                       *
 *  or inline functions from this file, or you compile this file and         *
 *  link it with other files to produce an executable, this file does        *
 *  not by itself cause the resulting executable to be covered by the        *
 *  GNU Lesser General Public License. This exception does not however       *
 *  invalidate any other reasons why the executable file might be            *
 *  covered by the GNU Lesser General Public License.                        *
 *                                                                           *
 *  OpenVolumeMesh is distributed in the hope that it will be useful,        *
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of           *
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            *
 *  GNU Lesser General Public License for more details.                      *
 *                                                                           *
 *  You should have received a copy of the GNU LesserGeneral Public          *
 *  License along with OpenVolumeMesh.  If not,                              *
 *  see <http://www.gnu.org/licenses/>.                                      *
 *                                                                           *
\*===========================================================================*/

/*===========================================================================*\
 *                                                                           *
 *   $Revision$                                                         *
 *   $Date$                    *
 *   $LastChangedBy$                                                *
 *                                                                           *
\*===========================================================================*/

#ifndef BASEENTITIES_HH_
#define BASEENTITIES_HH_

#include <vector>

#include "OpenVolumeMeshHandle.hh"

namespace OpenVolumeMesh {

class OpenVolumeMeshEdge {
53
friend class TopologyKernel;
54 55 56 57 58 59 60 61 62 63
public:
    OpenVolumeMeshEdge(const VertexHandle& _fromVertex,
                       const VertexHandle& _toVertex) :
        fromVertex_(_fromVertex),
        toVertex_(_toVertex) {
    }

    virtual ~OpenVolumeMeshEdge() {
    }

64
    const VertexHandle& from_vertex() const {
65 66
        return fromVertex_;
    }
67
    const VertexHandle& to_vertex() const {
68 69 70
        return toVertex_;
    }

71 72
protected:

73 74 75 76 77 78
    void set_from_vertex(const VertexHandle& _vertex) {
        fromVertex_ = _vertex;
    }
    void set_to_vertex(const VertexHandle& _vertex) {
        toVertex_ = _vertex;
    }
79

80 81 82 83 84 85 86 87 88 89 90
private:
    VertexHandle fromVertex_;
    VertexHandle toVertex_;
};

// Stream operator for edges
std::ostream& operator<<(std::ostream& _os, const OpenVolumeMeshEdge& _edge);

//***************************************************************************

class OpenVolumeMeshFace {
91
friend class TopologyKernel;
92
public:
Jan Möbius's avatar
Jan Möbius committed
93
    explicit OpenVolumeMeshFace(const std::vector<HalfEdgeHandle>& _halfedges) :
94 95 96 97 98 99
        halfedges_(_halfedges) {
    }

    virtual ~OpenVolumeMeshFace() {
    }

100
    const std::vector<HalfEdgeHandle>& halfedges() const & {
101 102 103
        return halfedges_;
    }

104 105 106 107 108
    const std::vector<HalfEdgeHandle>& halfedges() const && = delete;
    std::vector<HalfEdgeHandle> halfedges() && {
        return std::move(halfedges_);
    }

109 110
protected:

111 112 113 114 115 116 117 118 119 120 121 122 123 124
    void set_halfedges(const std::vector<HalfEdgeHandle>& _halfedges) {
        halfedges_ = _halfedges;
    }

private:
    std::vector<HalfEdgeHandle> halfedges_;
};

// Stream operator for faces
std::ostream& operator<<(std::ostream& _os, const OpenVolumeMeshFace& _face);

//***************************************************************************

class OpenVolumeMeshCell {
125
friend class TopologyKernel;
126
public:
Jan Möbius's avatar
Jan Möbius committed
127
    explicit OpenVolumeMeshCell(const std::vector<HalfFaceHandle>& _halffaces) :
128 129 130 131 132 133
        halffaces_(_halffaces) {
    }

    virtual ~OpenVolumeMeshCell() {
    }

134
    const std::vector<HalfFaceHandle>& halffaces() const & {
135 136 137
        return halffaces_;
    }

138 139 140 141 142
    const std::vector<HalfFaceHandle>& halffaces() const && = delete;
    std::vector<HalfFaceHandle> halffaces() && {
        return std::move(halffaces_);
    }

143 144
protected:

145 146 147 148 149 150 151 152 153 154 155 156 157 158
    void set_halffaces(const std::vector<HalfFaceHandle>& _halffaces) {
        halffaces_ = _halffaces;
    }

private:
    std::vector<HalfFaceHandle> halffaces_;
};

// Stream operator for cells
std::ostream& operator<<(std::ostream& _os, const OpenVolumeMeshCell& _cell);

} // Namespace OpenVolumeMesh

#endif /* BASEENTITIES_HH_ */