Developer Documentation
Loading...
Searching...
No Matches
Python.cc
1
2/*===========================================================================*\
3* *
4* OpenFlipper *
5 * Copyright (c) 2001-2015, RWTH-Aachen University *
6 * Department of Computer Graphics and Multimedia *
7 * All rights reserved. *
8 * www.openflipper.org *
9 * *
10 *---------------------------------------------------------------------------*
11 * This file is part of OpenFlipper. *
12 *---------------------------------------------------------------------------*
13 * *
14 * Redistribution and use in source and binary forms, with or without *
15 * modification, are permitted provided that the following conditions *
16 * are met: *
17 * *
18 * 1. Redistributions of source code must retain the above copyright notice, *
19 * this list of conditions and the following disclaimer. *
20 * *
21 * 2. Redistributions in binary form must reproduce the above copyright *
22 * notice, this list of conditions and the following disclaimer in the *
23 * documentation and/or other materials provided with the distribution. *
24 * *
25 * 3. Neither the name of the copyright holder nor the names of its *
26 * contributors may be used to endorse or promote products derived from *
27 * this software without specific prior written permission. *
28 * *
29 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
30 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
31 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
32 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
33 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
34 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
35 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
36 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
37 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
38 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
39 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
40* *
41\*===========================================================================*/
42
43#include <pybind11/pybind11.h>
44#include <pybind11/embed.h>
45
46
47#include <PrimitivesGenerator.hh>
48#include <QString>
49#include <QChar>
50
51#include <OpenFlipper/BasePlugin/PythonFunctions.hh>
52#include <OpenFlipper/PythonInterpreter/PythonTypeConversions.hh>
53
54#include <QCoreApplication>
55
56namespace py = pybind11;
57
58
59
60PYBIND11_EMBEDDED_MODULE(PrimitivesGenerator, m) {
61
62 QObject* pluginPointer = getPluginPointer("PrimitivesGenerator");
63
64 if (!pluginPointer) {
65 std::cerr << "Error Getting plugin pointer for Plugin-PrimitivesGenerator" << std::endl;
66 return;
67 }
68
69 PrimitivesGeneratorPlugin* plugin = qobject_cast<PrimitivesGeneratorPlugin*>(pluginPointer);
70
71 if (!plugin) {
72 std::cerr << "Error converting plugin pointer for Plugin-PrimitivesGenerator" << std::endl;
73 return;
74 }
75
76 // Export our core. Make sure that the c++ worlds core object is not deleted if
77 // the python side gets deleted!!
78 py::class_< PrimitivesGeneratorPlugin,std::unique_ptr<PrimitivesGeneratorPlugin, py::nodelete> > generator(m, "PrimitivesGenerator");
79
80 // On the c++ side we will just return the existing core instance
81 // and prevent the system to recreate a new core as we need
82 // to work on the existing one.
83 generator.def(py::init([plugin]() { return plugin; }));
84
85
86 generator.def("addTriangulatedCylinder", &PrimitivesGeneratorPlugin::addTriangulatedCylinder,
87 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a triangulated cylinder (ObjectId is returned)").toLatin1().data(),
88 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Position (Bottom center vertex position)").toLatin1().data()) = Vector(0.0,0.0,0.0),
89 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center axis of cylinder").toLatin1().data()) = Vector(0.0,0.0,1.0),
90 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Radius").toLatin1().data()),
91 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Height").toLatin1().data()),
92 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Add Top vertex?").toLatin1().data()) = true,
93 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Add bottom vertex?").toLatin1().data()) = true );
94
95 generator.def("addSphere", &PrimitivesGeneratorPlugin::addSphere,
96 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a triangulated sphere with all vertical lines connected to the poles (ObjectId is returned)").toLatin1().data(),
97 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Position (Sphere center)").toLatin1().data()) = Vector(0.0,0.0,0.0),
98 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Radius").toLatin1().data()) = 1.0);
99
100 generator.def("addSubdivisionSphere", &PrimitivesGeneratorPlugin::addSubdivisionSphere,
101 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a triangulated sphere by subdivision without poles. (ObjectId is returned)").toLatin1().data(),
102 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Position (Sphere center)").toLatin1().data()) = Vector(0.0,0.0,0.0),
103 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Radius").toLatin1().data()) = 1.0);
104
105 generator.def("addTetrahedron", &PrimitivesGeneratorPlugin::addTetrahedron,
106 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a tetrahedron (ObjectId is returned)").toLatin1().data(),
107 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center position").toLatin1().data()) = Vector(0.0,0.0,0.0),
108 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 1.0);
109
110 generator.def("addPyramid", &PrimitivesGeneratorPlugin::addPyramid,
111 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a pyramid (ObjectId is returned)").toLatin1().data(),
112 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center position").toLatin1().data()) = Vector(0.0,0.0,0.0),
113 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 2.0);
114
115 generator.def("addCube", &PrimitivesGeneratorPlugin::addCube,
116 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a poly mesh of cube (ObjectId is returned)").toLatin1().data(),
117 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center position").toLatin1().data()) = Vector(0.0,0.0,0.0),
118 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 2.0);
119
120 generator.def("addTriangulatedCube", &PrimitivesGeneratorPlugin::addTriangulatedCube,
121 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a triangular mesh of cube (ObjectId is returned)").toLatin1().data(),
122 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center position").toLatin1().data()) = Vector(0.0,0.0,0.0),
123 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 2.0);
124
125 generator.def("addTriangulatedPlaneFlat", &PrimitivesGeneratorPlugin::addTriangulatedPlaneFlat,
126 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a flat triangular planar mesh in the z plane (ObjectId is returned)").toLatin1().data(),
127 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Corner position").toLatin1().data()) = Vector(0.0,0.0,0.0),
128 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Size in X direction").toLatin1().data()) = 2.0,
129 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Size in Y direction").toLatin1().data()) = 2.0,
130 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of linesegments in x direction").toLatin1().data()) = 10,
131 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of linesegments in y direction").toLatin1().data()) = 10);
132
133 generator.def("addTriangulatedPlaneBumpy", &PrimitivesGeneratorPlugin::addTriangulatedPlaneBumpy,
134 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a bumpy triangular planar mesh in the z plane (ObjectId is returned)").toLatin1().data(),
135 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Corner position").toLatin1().data()) = Vector(0.0,0.0,0.0),
136 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Size in X direction").toLatin1().data()) = 10.0,
137 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Size in Y direction").toLatin1().data()) = 10.0,
138 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of linesegments in x direction").toLatin1().data()) = 200,
139 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of linesegments in y direction").toLatin1().data()) = 200);
140
141
142 generator.def("addTriangulatedPlanesNonManifold", &PrimitivesGeneratorPlugin::addTriangulatedPlanesNonManifold,
143 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates two perpendicular planes in a non manifold config (ObjectId is returned)").toLatin1().data(),
144 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Corner position").toLatin1().data()) = Vector(0.0,0.0,0.0),
145 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Size in X direction").toLatin1().data()) = 2.0,
146 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Size in Y direction").toLatin1().data()) = 2.0,
147 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Size in Z direction").toLatin1().data()) = 1.0,
148 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of linesegments in x direction").toLatin1().data()) = 50,
149 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of linesegments in y direction").toLatin1().data()) = 50,
150 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of linesegments in y direction").toLatin1().data()) = 50);
151
152 generator.def("addIcosahedron", &PrimitivesGeneratorPlugin::addIcosahedron,
153 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates an Icosahedron (ObjectId is returned)").toLatin1().data(),
154 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center position").toLatin1().data()) = Vector(0.0,0.0,0.0),
155 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 2.0);
156
157 generator.def("addOctahedron", &PrimitivesGeneratorPlugin::addOctahedron,
158 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates an Octahedron (ObjectId is returned)").toLatin1().data(),
159 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center position").toLatin1().data()) = Vector(0.0,0.0,0.0),
160 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 2.0);
161
162 generator.def("addDodecahedron", &PrimitivesGeneratorPlugin::addDodecahedron,
163 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a Dodecahedron (ObjectId is returned)").toLatin1().data(),
164 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center position").toLatin1().data()) = Vector(0.0,0.0,0.0),
165 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 2.0);
166
167#ifdef ENABLE_BSPLINECURVE_SUPPORT
168 generator.def("addRandomBSplineCurve", &PrimitivesGeneratorPlugin::addRandomBSplineCurve,
169 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a random B-spline curve (ObjectId is returned)").toLatin1().data(),
170 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Position").toLatin1().data()) = Vector(0.0,0.0,0.0),
171 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of control points").toLatin1().data()) = 5);
172#endif
173
174
175#ifdef ENABLE_BSPLINESURFACE_SUPPORT
176 generator.def("addRandomBSplineSurface", &PrimitivesGeneratorPlugin::addRandomBSplineSurface,
177 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a random B-spline surface (ObjectId is returned)").toLatin1().data(),
178 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Position").toLatin1().data()) = Vector(0.0,0.0,0.0),
179 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of control points").toLatin1().data()) = 5);
180#endif
181
182#ifdef ENABLE_POLYHEDRALMESH_SUPPORT
183 generator.def("addTetrahedralCube", &PrimitivesGeneratorPlugin::addTetrahedralCube,
184 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a tetrahedral mesh of a cube (ObjectId is returned)").toLatin1().data(),
185 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center Position").toLatin1().data()) = Vector(0.0,0.0,0.0),
186 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 2.0);
187
188 generator.def("addTetrahedralCuboid", &PrimitivesGeneratorPlugin::addTetrahedralCuboid,
189 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a tetrahedral mesh of a cuboid (ObjectId is returned)").toLatin1().data(),
190 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center Position").toLatin1().data()) = Vector(0.0,0.0,0.0),
191 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each side").toLatin1().data()) = Vector(4.0,6.0,12.0),
192 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of units in x-axis").toLatin1().data()) = 5,
193 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of units in y-axis").toLatin1().data()) = 5,
194 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Number of units in z-axis").toLatin1().data()) = 10);
195
196#endif
197
198#ifdef ENABLE_HEXAHEDRALMESH_SUPPORT
199 generator.def("addHexahedralCube", &PrimitivesGeneratorPlugin::addHexahedralCube,
200 QCoreApplication::translate("PythonDocPrimitivesGenerator","Generates a hexahedral mesh of a cube (ObjectId is returned)").toLatin1().data(),
201 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Center Position").toLatin1().data()) = Vector(0.0,0.0,0.0),
202 py::arg(QCoreApplication::translate("PythonDocPrimitivesGenerator","Length of each edge").toLatin1().data()) = 2.0);
203
204#endif
205
206}
ACG::Vec3d Vector
Standard Type for 3d Vector used for scripting.
Definition DataTypes.hh:176