-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathPluginFunctionsPolyhedralMesh.hh
113 lines (95 loc) · 5.34 KB
/
PluginFunctionsPolyhedralMesh.hh
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*===========================================================================*\
* *
* OpenFlipper *
* Copyright (C) 2001-2011 by Computer Graphics Group, RWTH Aachen *
* www.openflipper.org *
* *
*--------------------------------------------------------------------------- *
* This file is part of OpenFlipper. *
* *
* OpenFlipper 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. *
* *
* OpenFlipper 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 OpenFlipper. If not, *
* see <http://www.gnu.org/licenses/>. *
* *
\*===========================================================================*/
/*===========================================================================*\
* *
* $Revision: 13489 $ *
* $LastChangedBy: kremer $ *
* $Date: 2012-01-25 12:30:09 +0100 (Mi, 25 Jan 2012) $ *
* *
\*===========================================================================*/
/**
* \file PluginFunctionsPolyhedralMesh.hh
* This file contains functions which can be used by plugins to access
* PolyhedralMeshes in the framework.
*/
//
#ifndef PLUGINFUNCTIONSPOLYHEDRALMESH_HH
#define PLUGINFUNCTIONSPOLYHEDRALMESH_HH
#include <ObjectTypes/VolumeMeshObject/VolumeMeshObject.hh>
#include <ObjectTypes/PolyhedralMesh/PolyhedralMesh.hh>
#include <OpenFlipper/common/Types.hh>
//== NAMESPACES ===============================================================
/** The Namespace PluginFunctions contains functions for all plugins. */
namespace PluginFunctions {
/** \brief Get a pointer to every PolyhedralMesh which is marked as a source.
*
* @param _meshes ( vector returning the source polyhedral meshes )
* @return false, if no polyhedral mesh is selected as source
*/
DLLEXPORT
bool getSourceMeshes( std::vector<PolyhedralMesh*>& _meshes );
/** \brief Get a pointer to every PolyhedralMesh which is marked as a target.
*
* @param _meshes ( vector returning the target polyhedral meshes )
* @return false, if no polyhedral mesh is selected as target
*/
DLLEXPORT
bool getTargetMeshes( std::vector<PolyhedralMesh*>& _meshes );
/** This functions returns the object with the given id if it is an PolyhedralMeshObject.
* See get_object( int _identifier , BaseObject*& _object ) for more details.
*/
DLLEXPORT
bool getObject( int _identifier, PolyhedralMeshObject*& _object );
/** \brief Get an PolyhedralMesh from an object.
*
* @param _object The object should be of type BaseDataObject. If the content is
* a polyhedral mesh, a polyhedral mesh will be returned. Otherwise a NULL pointer is returned.
*/
DLLEXPORT
PolyhedralMesh* polyhedralMesh( BaseObjectData* _object );
/** \brief Cast an BaseObject to an PolyhedralMeshObject if possible
*
* @param _object The object should be of type BaseDataObject. If the content is
* an PolyhedralMesh, an PolyhedralMeshObject is returned. Otherwise a NULL pointer is returned.
*/
DLLEXPORT
PolyhedralMeshObject* polyhedralMeshObject( BaseObjectData* _object );
/** \brief Cast an int to an PolyhedralMeshObject if possible
*
* @param _identifier
*/
DLLEXPORT
PolyhedralMeshObject* polyhedralMeshObject( int _identifier );
}
#endif // PLUGINFUNCTIONSOPENVOLUMEMESH_HH