| |
|
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| |
|
| | #include "GeometryPyCXX.h"
|
| |
|
| |
|
| | #include "BoundBoxPy.h"
|
| | #include "BoundBoxPy.cpp"
|
| |
|
| | #include "MatrixPy.h"
|
| | #include "VectorPy.h"
|
| |
|
| | using namespace Base;
|
| |
|
| |
|
| | std::string BoundBoxPy::representation() const
|
| | {
|
| | std::stringstream str;
|
| | str << "BoundBox (";
|
| | str << getBoundBoxPtr()->MinX << ", " << getBoundBoxPtr()->MinY << ", "
|
| | << getBoundBoxPtr()->MinZ << ", " << getBoundBoxPtr()->MaxX << ", "
|
| | << getBoundBoxPtr()->MaxY << ", " << getBoundBoxPtr()->MaxZ;
|
| | str << ")";
|
| |
|
| | return str.str();
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::PyMake(PyTypeObject* , PyObject* , PyObject* )
|
| | {
|
| |
|
| | return new BoundBoxPy(new BoundBox3d);
|
| | }
|
| |
|
| |
|
| | int BoundBoxPy::PyInit(PyObject* args, PyObject* )
|
| | {
|
| | if (PyArg_ParseTuple(args, "")) {
|
| | return 0;
|
| | }
|
| | PyErr_Clear();
|
| |
|
| | double xMin = 0.0;
|
| | double yMin = 0.0;
|
| | double zMin = 0.0;
|
| | double xMax = 0.0;
|
| | double yMax = 0.0;
|
| | double zMax = 0.0;
|
| | PyObject* object1 {};
|
| | PyObject* object2 {};
|
| | BoundBoxPy::PointerType ptr = getBoundBoxPtr();
|
| | if (PyArg_ParseTuple(args, "d|ddddd", &xMin, &yMin, &zMin, &xMax, &yMax, &zMax)) {
|
| | ptr->MaxX = xMax;
|
| | ptr->MaxY = yMax;
|
| | ptr->MaxZ = zMax;
|
| | ptr->MinX = xMin;
|
| | ptr->MinY = yMin;
|
| | ptr->MinZ = zMin;
|
| | return 0;
|
| | }
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!O!", &PyTuple_Type, &object1, &PyTuple_Type, &object2)) {
|
| | try {
|
| | Vector3d v1 = getVectorFromTuple<double>(object1);
|
| | Vector3d v2 = getVectorFromTuple<double>(object2);
|
| | ptr->Add(v1);
|
| | ptr->Add(v2);
|
| | return 0;
|
| | }
|
| | catch (const Py::Exception&) {
|
| | return -1;
|
| | }
|
| | }
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!O!", &(VectorPy::Type), &object1, &(VectorPy::Type), &object2)) {
|
| | ptr->Add(*(static_cast<VectorPy*>(object1)->getVectorPtr()));
|
| | ptr->Add(*(static_cast<VectorPy*>(object2)->getVectorPtr()));
|
| | return 0;
|
| | }
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &(BoundBoxPy::Type), &object1)) {
|
| | *ptr = *(static_cast<BoundBoxPy*>(object1)->getBoundBoxPtr());
|
| | return 0;
|
| | }
|
| |
|
| | PyErr_SetString(
|
| | PyExc_TypeError,
|
| | "Either six floats, two instances of "
|
| | "Vector/Tuple or instance of BoundBox expected"
|
| | );
|
| | return -1;
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::setVoid(PyObject* args)
|
| | {
|
| | if (!PyArg_ParseTuple(args, "")) {
|
| | return nullptr;
|
| | }
|
| |
|
| | getBoundBoxPtr()->SetVoid();
|
| | Py_Return;
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::isValid(PyObject* args) const
|
| | {
|
| | if (!PyArg_ParseTuple(args, "")) {
|
| | return nullptr;
|
| | }
|
| |
|
| | return PyBool_FromLong(getBoundBoxPtr()->IsValid() ? 1 : 0);
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::add(PyObject* args)
|
| | {
|
| | double x {};
|
| | double y {};
|
| | double z {};
|
| | PyObject* object {};
|
| | if (PyArg_ParseTuple(args, "ddd", &x, &y, &z)) {
|
| | getBoundBoxPtr()->Add(Vector3d(x, y, z));
|
| | Py_Return;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &PyTuple_Type, &object)) {
|
| | getBoundBoxPtr()->Add(getVectorFromTuple<double>(object));
|
| | Py_Return;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &(VectorPy::Type), &object)) {
|
| | getBoundBoxPtr()->Add(*(static_cast<VectorPy*>(object)->getVectorPtr()));
|
| | Py_Return;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(
|
| | args,
|
| | "O!;Need a Vector, BoundBox or three floats as argument",
|
| | &(BoundBoxPy::Type),
|
| | &object
|
| | )) {
|
| | getBoundBoxPtr()->Add(*(static_cast<BoundBoxPy*>(object)->getBoundBoxPtr()));
|
| | Py_Return;
|
| | }
|
| |
|
| | PyErr_SetString(
|
| | PyExc_TypeError,
|
| | "Either three floats, instance of Vector or instance of BoundBox expected"
|
| | );
|
| | return nullptr;
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::getPoint(PyObject* args) const
|
| | {
|
| | unsigned short index {};
|
| | if (!PyArg_ParseTuple(args, "H", &index)) {
|
| | return nullptr;
|
| | }
|
| |
|
| | if (index > 7) {
|
| | PyErr_SetString(PyExc_IndexError, "Invalid point index");
|
| | return nullptr;
|
| | }
|
| |
|
| | return new VectorPy(new Vector3d(getBoundBoxPtr()->CalcPoint(index)));
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::getEdge(PyObject* args) const
|
| | {
|
| | unsigned short index {};
|
| | if (!PyArg_ParseTuple(args, "H", &index)) {
|
| | return nullptr;
|
| | }
|
| |
|
| | if (index > 11) {
|
| | PyErr_SetString(PyExc_IndexError, "Invalid edge index");
|
| | return nullptr;
|
| | }
|
| |
|
| | Vector3d pnt1;
|
| | Vector3d pnt2;
|
| | getBoundBoxPtr()->CalcEdge(index, pnt1, pnt2);
|
| | Py::Tuple tuple(2);
|
| | tuple.setItem(0, Py::Vector(pnt1));
|
| | tuple.setItem(1, Py::Vector(pnt2));
|
| | return Py::new_reference_to(tuple);
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::closestPoint(PyObject* args) const
|
| | {
|
| | double x {};
|
| | double y {};
|
| | double z {};
|
| | PyObject* object {};
|
| |
|
| | Vector3d vec;
|
| |
|
| | do {
|
| | if (PyArg_ParseTuple(args, "ddd", &x, &y, &z)) {
|
| | vec = Vector3d(x, y, z);
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &PyTuple_Type, &object)) {
|
| | vec = getVectorFromTuple<double>(object);
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &(VectorPy::Type), &object)) {
|
| | vec = *(static_cast<VectorPy*>(object)->getVectorPtr());
|
| | break;
|
| | }
|
| |
|
| | PyErr_SetString(PyExc_TypeError, "Either three floats or vector expected");
|
| | return nullptr;
|
| | } while (false);
|
| |
|
| | Vector3d point = getBoundBoxPtr()->ClosestPoint(vec);
|
| | return new VectorPy(new Vector3d(point));
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::intersect(PyObject* args)
|
| | {
|
| | PyObject* object1 {};
|
| | PyObject* object2 {};
|
| | Py::Boolean retVal;
|
| |
|
| | if (!getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box");
|
| | return nullptr;
|
| | }
|
| |
|
| | do {
|
| | if (PyArg_ParseTuple(args, "O!O!", &(VectorPy::Type), &object1, &(VectorPy::Type), &object2)) {
|
| | retVal = getBoundBoxPtr()->IsCutLine(
|
| | *(static_cast<VectorPy*>(object1)->getVectorPtr()),
|
| | *(static_cast<VectorPy*>(object2)->getVectorPtr())
|
| | );
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &(BoundBoxPy::Type), &object1)) {
|
| | if (!static_cast<BoundBoxPy*>(object1)->getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box argument");
|
| | return nullptr;
|
| | }
|
| | retVal = getBoundBoxPtr()->Intersect(
|
| | *(static_cast<BoundBoxPy*>(object1)->getBoundBoxPtr())
|
| | );
|
| | break;
|
| | }
|
| |
|
| | PyErr_SetString(PyExc_TypeError, "Either BoundBox or two Vectors expected");
|
| | return nullptr;
|
| | } while (false);
|
| |
|
| | return Py::new_reference_to(retVal);
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::intersected(PyObject* args)
|
| | {
|
| | if (!getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box");
|
| | return nullptr;
|
| | }
|
| |
|
| | PyObject* object {};
|
| | if (!PyArg_ParseTuple(args, "O!", &(BoundBoxPy::Type), &object)) {
|
| | return nullptr;
|
| | }
|
| | if (!static_cast<BoundBoxPy*>(object)->getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box argument");
|
| | return nullptr;
|
| | }
|
| |
|
| | BoundBox3d bbox = getBoundBoxPtr()->Intersected(
|
| | *static_cast<BoundBoxPy*>(object)->getBoundBoxPtr()
|
| | );
|
| | return new BoundBoxPy(new BoundBox3d(bbox));
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::united(PyObject* args)
|
| | {
|
| | if (!getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box");
|
| | return nullptr;
|
| | }
|
| |
|
| | PyObject* object {};
|
| | if (!PyArg_ParseTuple(args, "O!", &(BoundBoxPy::Type), &object)) {
|
| | return nullptr;
|
| | }
|
| | if (!static_cast<BoundBoxPy*>(object)->getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box argument");
|
| | return nullptr;
|
| | }
|
| |
|
| | BoundBox3d bbox = getBoundBoxPtr()->United(*static_cast<BoundBoxPy*>(object)->getBoundBoxPtr());
|
| | return new BoundBoxPy(new BoundBox3d(bbox));
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::enlarge(PyObject* args)
|
| | {
|
| | double s {};
|
| | if (!PyArg_ParseTuple(args, "d;Need float parameter to enlarge", &s)) {
|
| | return nullptr;
|
| | }
|
| | getBoundBoxPtr()->Enlarge(s);
|
| | Py_Return;
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::getIntersectionPoint(PyObject* args)
|
| | {
|
| | PyObject* object1 {};
|
| | PyObject* object2 {};
|
| | double epsilon = 0.0001;
|
| | if (!PyArg_ParseTuple(
|
| | args,
|
| | "O!O!|d;Need base and direction vector",
|
| | &(VectorPy::Type),
|
| | &object1,
|
| | &(VectorPy::Type),
|
| | &object2,
|
| | &epsilon
|
| | )) {
|
| | return nullptr;
|
| | }
|
| |
|
| | Vector3d point;
|
| | bool ok = getBoundBoxPtr()->IntersectionPoint(
|
| | *(static_cast<VectorPy*>(object1)->getVectorPtr()),
|
| | *(static_cast<VectorPy*>(object2)->getVectorPtr()),
|
| | point,
|
| | epsilon
|
| | );
|
| | if (ok) {
|
| | return new VectorPy(point);
|
| | }
|
| |
|
| | PyErr_SetString(PyExc_FC_GeneralError, "No intersection");
|
| | return nullptr;
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::move(PyObject* args)
|
| | {
|
| | double x {};
|
| | double y {};
|
| | double z {};
|
| | PyObject* object {};
|
| |
|
| | Vector3d vec;
|
| |
|
| | do {
|
| | if (PyArg_ParseTuple(args, "ddd", &x, &y, &z)) {
|
| | vec = Vector3d(x, y, z);
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &PyTuple_Type, &object)) {
|
| | vec = getVectorFromTuple<double>(object);
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &(VectorPy::Type), &object)) {
|
| | vec = *(static_cast<VectorPy*>(object)->getVectorPtr());
|
| | break;
|
| | }
|
| |
|
| | PyErr_SetString(PyExc_TypeError, "Either three floats or vector expected");
|
| | return nullptr;
|
| | } while (false);
|
| |
|
| | getBoundBoxPtr()->MoveX(vec.x);
|
| | getBoundBoxPtr()->MoveY(vec.y);
|
| | getBoundBoxPtr()->MoveZ(vec.z);
|
| |
|
| | Py_Return;
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::scale(PyObject* args)
|
| | {
|
| | double x {};
|
| | double y {};
|
| | double z {};
|
| | PyObject* object {};
|
| |
|
| | Vector3d vec;
|
| |
|
| | do {
|
| | if (PyArg_ParseTuple(args, "ddd", &x, &y, &z)) {
|
| | vec = Vector3d(x, y, z);
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &PyTuple_Type, &object)) {
|
| | vec = getVectorFromTuple<double>(object);
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &(VectorPy::Type), &object)) {
|
| | vec = *(static_cast<VectorPy*>(object)->getVectorPtr());
|
| | break;
|
| | }
|
| |
|
| | PyErr_SetString(PyExc_TypeError, "Either three floats or vector expected");
|
| | return nullptr;
|
| | } while (false);
|
| |
|
| | getBoundBoxPtr()->ScaleX(vec.x);
|
| | getBoundBoxPtr()->ScaleY(vec.y);
|
| | getBoundBoxPtr()->ScaleZ(vec.z);
|
| |
|
| | Py_Return;
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::transformed(PyObject* args)
|
| | {
|
| | PyObject* mat {};
|
| |
|
| | if (!PyArg_ParseTuple(args, "O!", &(MatrixPy::Type), &mat)) {
|
| | return nullptr;
|
| | }
|
| |
|
| | if (!getBoundBoxPtr()->IsValid()) {
|
| | throw Py::FloatingPointError("Cannot transform invalid bounding box");
|
| | }
|
| | BoundBox3d bbox = getBoundBoxPtr()->Transformed(*static_cast<MatrixPy*>(mat)->getMatrixPtr());
|
| | return new BoundBoxPy(new BoundBox3d(bbox));
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::isCutPlane(PyObject* args)
|
| | {
|
| | PyObject* object {};
|
| | PyObject* object2 {};
|
| | Py::Boolean retVal;
|
| |
|
| | if (!getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box");
|
| | return nullptr;
|
| | }
|
| |
|
| | if (!PyArg_ParseTuple(
|
| | args,
|
| | "O!O!;Need base and normal vector of a plane",
|
| | &(VectorPy::Type),
|
| | &object,
|
| | &(VectorPy::Type),
|
| | &object2
|
| | )) {
|
| | return nullptr;
|
| | }
|
| |
|
| | retVal = getBoundBoxPtr()->IsCutPlane(
|
| | *(static_cast<VectorPy*>(object)->getVectorPtr()),
|
| | *(static_cast<VectorPy*>(object2)->getVectorPtr())
|
| | );
|
| |
|
| | return Py::new_reference_to(retVal);
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::isInside(PyObject* args)
|
| | {
|
| | double x {};
|
| | double y {};
|
| | double z {};
|
| | PyObject* object {};
|
| | Py::Boolean retVal;
|
| |
|
| | if (!getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box");
|
| | return nullptr;
|
| | }
|
| |
|
| | do {
|
| | if (PyArg_ParseTuple(args, "ddd", &x, &y, &z)) {
|
| | retVal = getBoundBoxPtr()->IsInBox(Vector3d(x, y, z));
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &PyTuple_Type, &object)) {
|
| | retVal = getBoundBoxPtr()->IsInBox(getVectorFromTuple<double>(object));
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &(VectorPy::Type), &object)) {
|
| | retVal = getBoundBoxPtr()->IsInBox(*(static_cast<VectorPy*>(object)->getVectorPtr()));
|
| | break;
|
| | }
|
| |
|
| | PyErr_Clear();
|
| | if (PyArg_ParseTuple(args, "O!", &(BoundBoxPy::Type), &object)) {
|
| | if (!static_cast<BoundBoxPy*>(object)->getBoundBoxPtr()->IsValid()) {
|
| | PyErr_SetString(PyExc_FloatingPointError, "Invalid bounding box argument");
|
| | return nullptr;
|
| | }
|
| | retVal = getBoundBoxPtr()->IsInBox(*(static_cast<BoundBoxPy*>(object)->getBoundBoxPtr()));
|
| | break;
|
| | }
|
| |
|
| | PyErr_SetString(PyExc_TypeError, "Either three floats, Vector(s) or BoundBox expected");
|
| | return nullptr;
|
| | } while (false);
|
| |
|
| | return Py::new_reference_to(retVal);
|
| | }
|
| |
|
| | Py::Object BoundBoxPy::getCenter() const
|
| | {
|
| | return Py::Vector(getBoundBoxPtr()->GetCenter());
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getXMax() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->MaxX);
|
| | }
|
| |
|
| | void BoundBoxPy::setXMax(Py::Float arg)
|
| | {
|
| | getBoundBoxPtr()->MaxX = arg;
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getYMax() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->MaxY);
|
| | }
|
| |
|
| | void BoundBoxPy::setYMax(Py::Float arg)
|
| | {
|
| | getBoundBoxPtr()->MaxY = arg;
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getZMax() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->MaxZ);
|
| | }
|
| |
|
| | void BoundBoxPy::setZMax(Py::Float arg)
|
| | {
|
| | getBoundBoxPtr()->MaxZ = arg;
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getXMin() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->MinX);
|
| | }
|
| |
|
| | void BoundBoxPy::setXMin(Py::Float arg)
|
| | {
|
| | getBoundBoxPtr()->MinX = arg;
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getYMin() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->MinY);
|
| | }
|
| |
|
| | void BoundBoxPy::setYMin(Py::Float arg)
|
| | {
|
| | getBoundBoxPtr()->MinY = arg;
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getZMin() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->MinZ);
|
| | }
|
| |
|
| | void BoundBoxPy::setZMin(Py::Float arg)
|
| | {
|
| | getBoundBoxPtr()->MinZ = arg;
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getXLength() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->LengthX());
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getYLength() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->LengthY());
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getZLength() const
|
| | {
|
| | return Py::Float(getBoundBoxPtr()->LengthZ());
|
| | }
|
| |
|
| | Py::Float BoundBoxPy::getDiagonalLength() const
|
| | {
|
| | if (!getBoundBoxPtr()->IsValid()) {
|
| | throw Py::FloatingPointError("Cannot determine diagonal length of invalid bounding box");
|
| | }
|
| | return Py::Float(getBoundBoxPtr()->CalcDiagonalLength());
|
| | }
|
| |
|
| | PyObject* BoundBoxPy::getCustomAttributes(const char* ) const
|
| | {
|
| | return nullptr;
|
| | }
|
| |
|
| | int BoundBoxPy::setCustomAttributes(const char* , PyObject* )
|
| | {
|
| | return 0;
|
| | }
|
| |
|