2021-12-05 20:49:36 +08:00
|
|
|
// must be defined before importing numpy headers
|
|
|
|
// https://numpy.org/doc/1.17/reference/c-api.array.html#importing-the-api
|
|
|
|
#define PY_ARRAY_UNIQUE_SYMBOL opencv_ARRAY_API
|
2019-03-21 15:45:02 +08:00
|
|
|
|
2021-12-05 20:49:36 +08:00
|
|
|
#include "cv2.hpp"
|
2019-03-21 15:45:02 +08:00
|
|
|
|
2021-01-30 19:32:27 +08:00
|
|
|
#include "opencv2/opencv_modules.hpp"
|
|
|
|
#include "opencv2/core.hpp"
|
2019-11-15 23:37:56 +08:00
|
|
|
#include "opencv2/core/utils/logger.hpp"
|
|
|
|
|
2019-03-21 15:45:02 +08:00
|
|
|
#include "pyopencv_generated_include.h"
|
|
|
|
#include "opencv2/core/types_c.h"
|
2021-01-12 22:50:07 +08:00
|
|
|
|
|
|
|
|
2021-12-05 20:49:36 +08:00
|
|
|
#include "cv2_util.hpp"
|
|
|
|
#include "cv2_numpy.hpp"
|
|
|
|
#include "cv2_convert.hpp"
|
|
|
|
#include "cv2_highgui.hpp"
|
2010-10-29 21:09:49 +08:00
|
|
|
|
2010-11-03 01:58:22 +08:00
|
|
|
using namespace cv;
|
|
|
|
|
2013-02-25 00:14:01 +08:00
|
|
|
typedef std::vector<uchar> vector_uchar;
|
2013-07-11 11:58:37 +08:00
|
|
|
typedef std::vector<char> vector_char;
|
2013-02-25 00:14:01 +08:00
|
|
|
typedef std::vector<int> vector_int;
|
|
|
|
typedef std::vector<float> vector_float;
|
|
|
|
typedef std::vector<double> vector_double;
|
2017-10-14 07:27:37 +08:00
|
|
|
typedef std::vector<size_t> vector_size_t;
|
2013-02-25 00:14:01 +08:00
|
|
|
typedef std::vector<Point> vector_Point;
|
|
|
|
typedef std::vector<Point2f> vector_Point2f;
|
2015-10-11 12:12:42 +08:00
|
|
|
typedef std::vector<Point3f> vector_Point3f;
|
2018-12-19 02:49:16 +08:00
|
|
|
typedef std::vector<Size> vector_Size;
|
2013-02-25 00:14:01 +08:00
|
|
|
typedef std::vector<Vec2f> vector_Vec2f;
|
|
|
|
typedef std::vector<Vec3f> vector_Vec3f;
|
|
|
|
typedef std::vector<Vec4f> vector_Vec4f;
|
|
|
|
typedef std::vector<Vec6f> vector_Vec6f;
|
|
|
|
typedef std::vector<Vec4i> vector_Vec4i;
|
|
|
|
typedef std::vector<Rect> vector_Rect;
|
2015-10-30 17:02:33 +08:00
|
|
|
typedef std::vector<Rect2d> vector_Rect2d;
|
2018-08-24 14:22:07 +08:00
|
|
|
typedef std::vector<RotatedRect> vector_RotatedRect;
|
2013-02-25 00:14:01 +08:00
|
|
|
typedef std::vector<KeyPoint> vector_KeyPoint;
|
|
|
|
typedef std::vector<Mat> vector_Mat;
|
2017-10-14 07:27:37 +08:00
|
|
|
typedef std::vector<std::vector<Mat> > vector_vector_Mat;
|
2016-02-08 00:04:39 +08:00
|
|
|
typedef std::vector<UMat> vector_UMat;
|
2013-02-25 00:14:01 +08:00
|
|
|
typedef std::vector<DMatch> vector_DMatch;
|
2013-03-23 00:37:49 +08:00
|
|
|
typedef std::vector<String> vector_String;
|
2020-01-28 18:16:03 +08:00
|
|
|
typedef std::vector<std::string> vector_string;
|
2014-05-12 18:58:54 +08:00
|
|
|
typedef std::vector<Scalar> vector_Scalar;
|
2013-07-11 11:58:37 +08:00
|
|
|
|
|
|
|
typedef std::vector<std::vector<char> > vector_vector_char;
|
2013-02-25 00:14:01 +08:00
|
|
|
typedef std::vector<std::vector<Point> > vector_vector_Point;
|
|
|
|
typedef std::vector<std::vector<Point2f> > vector_vector_Point2f;
|
|
|
|
typedef std::vector<std::vector<Point3f> > vector_vector_Point3f;
|
|
|
|
typedef std::vector<std::vector<DMatch> > vector_vector_DMatch;
|
2016-10-16 23:09:35 +08:00
|
|
|
typedef std::vector<std::vector<KeyPoint> > vector_vector_KeyPoint;
|
2011-09-07 17:38:22 +08:00
|
|
|
|
2021-12-05 20:49:36 +08:00
|
|
|
// enum { ARG_NONE = 0, ARG_MAT = 1, ARG_SCALAR = 2 };
|
2017-10-11 19:11:47 +08:00
|
|
|
|
2016-06-21 05:24:15 +08:00
|
|
|
|
2011-06-14 06:25:21 +08:00
|
|
|
///////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2019-11-15 22:29:51 +08:00
|
|
|
static int convert_to_char(PyObject *o, char *dst, const ArgInfo& info)
|
2013-04-12 21:39:16 +08:00
|
|
|
{
|
2019-03-21 15:45:02 +08:00
|
|
|
std::string str;
|
|
|
|
if (getUnicodeString(o, str))
|
|
|
|
{
|
|
|
|
*dst = str[0];
|
|
|
|
return 1;
|
|
|
|
}
|
2013-04-12 21:39:16 +08:00
|
|
|
(*dst) = 0;
|
2019-11-15 22:29:51 +08:00
|
|
|
return failmsg("Expected single character string for argument '%s'", info.name);
|
2013-04-12 21:39:16 +08:00
|
|
|
}
|
|
|
|
|
2012-06-21 01:57:26 +08:00
|
|
|
#ifdef __GNUC__
|
|
|
|
# pragma GCC diagnostic ignored "-Wunused-parameter"
|
|
|
|
# pragma GCC diagnostic ignored "-Wmissing-field-initializers"
|
|
|
|
#endif
|
|
|
|
|
2019-03-21 15:45:02 +08:00
|
|
|
|
2018-09-28 14:39:51 +08:00
|
|
|
#include "pyopencv_generated_enums.h"
|
2019-03-21 15:45:02 +08:00
|
|
|
|
|
|
|
#ifdef CVPY_DYNAMIC_INIT
|
2021-03-31 04:54:11 +08:00
|
|
|
#define CVPY_TYPE(WNAME, NAME, STORAGE, SNAME, _1, _2) CVPY_TYPE_DECLARE_DYNAMIC(WNAME, NAME, STORAGE, SNAME)
|
2019-03-21 15:45:02 +08:00
|
|
|
#else
|
2021-03-31 04:54:11 +08:00
|
|
|
#define CVPY_TYPE(WNAME, NAME, STORAGE, SNAME, _1, _2) CVPY_TYPE_DECLARE(WNAME, NAME, STORAGE, SNAME)
|
2019-03-21 15:45:02 +08:00
|
|
|
#endif
|
2011-05-04 00:00:31 +08:00
|
|
|
#include "pyopencv_generated_types.h"
|
2019-03-21 15:45:02 +08:00
|
|
|
#undef CVPY_TYPE
|
2020-09-18 03:00:03 +08:00
|
|
|
#include "pyopencv_custom_headers.h"
|
2019-03-21 15:45:02 +08:00
|
|
|
|
|
|
|
#include "pyopencv_generated_types_content.h"
|
2011-05-04 00:00:31 +08:00
|
|
|
#include "pyopencv_generated_funcs.h"
|
|
|
|
|
2021-08-16 04:33:06 +08:00
|
|
|
static PyObject* pycvRegisterMatType(PyObject *self, PyObject *value)
|
|
|
|
{
|
|
|
|
CV_LOG_DEBUG(NULL, cv::format("pycvRegisterMatType %p %p\n", self, value));
|
|
|
|
|
|
|
|
if (0 == PyType_Check(value))
|
|
|
|
{
|
|
|
|
PyErr_SetString(PyExc_TypeError, "Type argument is expected");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
Py_INCREF(value);
|
|
|
|
pyopencv_Mat_TypePtr = (PyTypeObject*)value;
|
|
|
|
|
|
|
|
Py_RETURN_NONE;
|
|
|
|
}
|
|
|
|
|
2014-08-19 18:57:47 +08:00
|
|
|
static PyMethodDef special_methods[] = {
|
2021-08-16 04:33:06 +08:00
|
|
|
{"_registerMatType", (PyCFunction)(pycvRegisterMatType), METH_O, "_registerMatType(cv.Mat) -> None (Internal)"},
|
2018-05-30 22:24:43 +08:00
|
|
|
{"redirectError", CV_PY_FN_WITH_KW(pycvRedirectError), "redirectError(onError) -> None"},
|
2015-04-07 07:57:10 +08:00
|
|
|
#ifdef HAVE_OPENCV_HIGHGUI
|
2018-05-30 22:24:43 +08:00
|
|
|
{"createTrackbar", (PyCFunction)pycvCreateTrackbar, METH_VARARGS, "createTrackbar(trackbarName, windowName, value, count, onChange) -> None"},
|
|
|
|
{"createButton", CV_PY_FN_WITH_KW(pycvCreateButton), "createButton(buttonName, onChange [, userData, buttonType, initialButtonState]) -> None"},
|
|
|
|
{"setMouseCallback", CV_PY_FN_WITH_KW(pycvSetMouseCallback), "setMouseCallback(windowName, onMouse [, param]) -> None"},
|
2018-04-25 20:19:02 +08:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_OPENCV_DNN
|
2018-05-30 22:24:43 +08:00
|
|
|
{"dnn_registerLayer", CV_PY_FN_WITH_KW(pyopencv_cv_dnn_registerLayer), "registerLayer(type, class) -> None"},
|
|
|
|
{"dnn_unregisterLayer", CV_PY_FN_WITH_KW(pyopencv_cv_dnn_unregisterLayer), "unregisterLayer(type) -> None"},
|
2015-04-07 07:57:10 +08:00
|
|
|
#endif
|
2011-05-04 00:00:31 +08:00
|
|
|
{NULL, NULL},
|
|
|
|
};
|
|
|
|
|
|
|
|
/************************************************************************/
|
|
|
|
/* Module init */
|
|
|
|
|
2014-08-19 17:35:46 +08:00
|
|
|
struct ConstDef
|
|
|
|
{
|
|
|
|
const char * name;
|
2019-02-26 18:15:59 +08:00
|
|
|
long long val;
|
2014-08-19 17:35:46 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static void init_submodule(PyObject * root, const char * name, PyMethodDef * methods, ConstDef * consts)
|
2014-08-16 00:44:32 +08:00
|
|
|
{
|
2014-08-18 20:52:01 +08:00
|
|
|
// traverse and create nested submodules
|
2014-08-16 00:44:32 +08:00
|
|
|
std::string s = name;
|
2014-08-18 20:52:01 +08:00
|
|
|
size_t i = s.find('.');
|
|
|
|
while (i < s.length() && i != std::string::npos)
|
2014-08-16 00:44:32 +08:00
|
|
|
{
|
|
|
|
size_t j = s.find('.', i);
|
|
|
|
if (j == std::string::npos)
|
|
|
|
j = s.length();
|
|
|
|
std::string short_name = s.substr(i, j-i);
|
|
|
|
std::string full_name = s.substr(0, j);
|
|
|
|
i = j+1;
|
|
|
|
|
|
|
|
PyObject * d = PyModule_GetDict(root);
|
|
|
|
PyObject * submod = PyDict_GetItemString(d, short_name.c_str());
|
|
|
|
if (submod == NULL)
|
|
|
|
{
|
|
|
|
submod = PyImport_AddModule(full_name.c_str());
|
|
|
|
PyDict_SetItemString(d, short_name.c_str(), submod);
|
|
|
|
}
|
2015-03-02 12:04:14 +08:00
|
|
|
|
|
|
|
if (short_name != "")
|
|
|
|
root = submod;
|
2014-08-16 00:44:32 +08:00
|
|
|
}
|
|
|
|
|
2014-08-18 20:52:01 +08:00
|
|
|
// populate module's dict
|
2014-08-16 00:44:32 +08:00
|
|
|
PyObject * d = PyModule_GetDict(root);
|
|
|
|
for (PyMethodDef * m = methods; m->ml_name != NULL; ++m)
|
|
|
|
{
|
|
|
|
PyObject * method_obj = PyCFunction_NewEx(m, NULL, NULL);
|
|
|
|
PyDict_SetItemString(d, m->ml_name, method_obj);
|
|
|
|
Py_DECREF(method_obj);
|
|
|
|
}
|
2014-08-19 17:35:46 +08:00
|
|
|
for (ConstDef * c = consts; c->name != NULL; ++c)
|
|
|
|
{
|
2019-02-26 18:15:59 +08:00
|
|
|
PyDict_SetItemString(d, c->name, PyLong_FromLongLong(c->val));
|
2014-08-19 17:35:46 +08:00
|
|
|
}
|
|
|
|
|
2014-08-16 00:44:32 +08:00
|
|
|
}
|
|
|
|
|
2019-03-21 15:45:02 +08:00
|
|
|
#include "pyopencv_generated_modules_content.h"
|
2014-08-16 00:44:32 +08:00
|
|
|
|
2019-03-21 15:45:02 +08:00
|
|
|
static bool init_body(PyObject * m)
|
2011-05-04 00:00:31 +08:00
|
|
|
{
|
2019-03-21 15:45:02 +08:00
|
|
|
#define CVPY_MODULE(NAMESTR, NAME) \
|
|
|
|
init_submodule(m, MODULESTR NAMESTR, methods_##NAME, consts_##NAME)
|
|
|
|
#include "pyopencv_generated_modules.h"
|
|
|
|
#undef CVPY_MODULE
|
|
|
|
|
|
|
|
#ifdef CVPY_DYNAMIC_INIT
|
2021-03-31 04:54:11 +08:00
|
|
|
#define CVPY_TYPE(WNAME, NAME, _1, _2, BASE, CONSTRUCTOR) CVPY_TYPE_INIT_DYNAMIC(WNAME, NAME, return false, BASE, CONSTRUCTOR)
|
2019-03-21 15:45:02 +08:00
|
|
|
PyObject * pyopencv_NoBase_TypePtr = NULL;
|
|
|
|
#else
|
2021-03-31 04:54:11 +08:00
|
|
|
#define CVPY_TYPE(WNAME, NAME, _1, _2, BASE, CONSTRUCTOR) CVPY_TYPE_INIT_STATIC(WNAME, NAME, return false, BASE, CONSTRUCTOR)
|
2019-03-21 15:45:02 +08:00
|
|
|
PyTypeObject * pyopencv_NoBase_TypePtr = NULL;
|
|
|
|
#endif
|
|
|
|
#include "pyopencv_generated_types.h"
|
|
|
|
#undef CVPY_TYPE
|
2011-05-04 00:00:31 +08:00
|
|
|
|
2019-03-21 15:45:02 +08:00
|
|
|
PyObject* d = PyModule_GetDict(m);
|
|
|
|
|
|
|
|
|
|
|
|
PyDict_SetItemString(d, "__version__", PyString_FromString(CV_VERSION));
|
|
|
|
|
|
|
|
PyObject *opencv_error_dict = PyDict_New();
|
|
|
|
PyDict_SetItemString(opencv_error_dict, "file", Py_None);
|
|
|
|
PyDict_SetItemString(opencv_error_dict, "func", Py_None);
|
|
|
|
PyDict_SetItemString(opencv_error_dict, "line", Py_None);
|
|
|
|
PyDict_SetItemString(opencv_error_dict, "code", Py_None);
|
|
|
|
PyDict_SetItemString(opencv_error_dict, "msg", Py_None);
|
|
|
|
PyDict_SetItemString(opencv_error_dict, "err", Py_None);
|
|
|
|
opencv_error = PyErr_NewException((char*)MODULESTR".error", NULL, opencv_error_dict);
|
|
|
|
Py_DECREF(opencv_error_dict);
|
|
|
|
PyDict_SetItemString(d, "error", opencv_error);
|
|
|
|
|
|
|
|
|
|
|
|
#define PUBLISH(I) PyDict_SetItemString(d, #I, PyInt_FromLong(I))
|
|
|
|
PUBLISH(CV_8U);
|
|
|
|
PUBLISH(CV_8UC1);
|
|
|
|
PUBLISH(CV_8UC2);
|
|
|
|
PUBLISH(CV_8UC3);
|
|
|
|
PUBLISH(CV_8UC4);
|
|
|
|
PUBLISH(CV_8S);
|
|
|
|
PUBLISH(CV_8SC1);
|
|
|
|
PUBLISH(CV_8SC2);
|
|
|
|
PUBLISH(CV_8SC3);
|
|
|
|
PUBLISH(CV_8SC4);
|
|
|
|
PUBLISH(CV_16U);
|
|
|
|
PUBLISH(CV_16UC1);
|
|
|
|
PUBLISH(CV_16UC2);
|
|
|
|
PUBLISH(CV_16UC3);
|
|
|
|
PUBLISH(CV_16UC4);
|
|
|
|
PUBLISH(CV_16S);
|
|
|
|
PUBLISH(CV_16SC1);
|
|
|
|
PUBLISH(CV_16SC2);
|
|
|
|
PUBLISH(CV_16SC3);
|
|
|
|
PUBLISH(CV_16SC4);
|
|
|
|
PUBLISH(CV_32S);
|
|
|
|
PUBLISH(CV_32SC1);
|
|
|
|
PUBLISH(CV_32SC2);
|
|
|
|
PUBLISH(CV_32SC3);
|
|
|
|
PUBLISH(CV_32SC4);
|
|
|
|
PUBLISH(CV_32F);
|
|
|
|
PUBLISH(CV_32FC1);
|
|
|
|
PUBLISH(CV_32FC2);
|
|
|
|
PUBLISH(CV_32FC3);
|
|
|
|
PUBLISH(CV_32FC4);
|
|
|
|
PUBLISH(CV_64F);
|
|
|
|
PUBLISH(CV_64FC1);
|
|
|
|
PUBLISH(CV_64FC2);
|
|
|
|
PUBLISH(CV_64FC3);
|
|
|
|
PUBLISH(CV_64FC4);
|
|
|
|
#undef PUBLISH
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
2013-06-13 04:03:34 +08:00
|
|
|
|
2019-06-04 22:40:24 +08:00
|
|
|
#if defined(__GNUC__)
|
|
|
|
#pragma GCC visibility push(default)
|
|
|
|
#endif
|
|
|
|
|
2020-01-13 23:11:34 +08:00
|
|
|
#if defined(CV_PYTHON_3)
|
2019-03-21 15:45:02 +08:00
|
|
|
// === Python 3
|
|
|
|
|
2013-06-13 04:03:34 +08:00
|
|
|
static struct PyModuleDef cv2_moduledef =
|
|
|
|
{
|
|
|
|
PyModuleDef_HEAD_INIT,
|
|
|
|
MODULESTR,
|
|
|
|
"Python wrapper for OpenCV.",
|
|
|
|
-1, /* size of per-interpreter state of the module,
|
|
|
|
or -1 if the module keeps state in global variables. */
|
2014-08-19 18:57:47 +08:00
|
|
|
special_methods
|
2013-06-13 04:03:34 +08:00
|
|
|
};
|
|
|
|
|
2019-03-21 15:45:02 +08:00
|
|
|
PyMODINIT_FUNC PyInit_cv2();
|
2013-06-13 04:03:34 +08:00
|
|
|
PyObject* PyInit_cv2()
|
2019-03-21 15:45:02 +08:00
|
|
|
{
|
|
|
|
import_array(); // from numpy
|
|
|
|
PyObject* m = PyModule_Create(&cv2_moduledef);
|
|
|
|
if (!init_body(m))
|
|
|
|
return NULL;
|
|
|
|
return m;
|
|
|
|
}
|
|
|
|
|
2013-06-13 04:03:34 +08:00
|
|
|
#else
|
2019-03-21 15:45:02 +08:00
|
|
|
// === Python 2
|
2019-06-04 22:40:24 +08:00
|
|
|
PyMODINIT_FUNC initcv2();
|
2011-05-04 00:00:31 +08:00
|
|
|
void initcv2()
|
|
|
|
{
|
2019-03-21 15:45:02 +08:00
|
|
|
import_array(); // from numpy
|
|
|
|
PyObject* m = Py_InitModule(MODULESTR, special_methods);
|
|
|
|
init_body(m);
|
|
|
|
}
|
2011-06-06 22:18:25 +08:00
|
|
|
|
2013-06-13 04:03:34 +08:00
|
|
|
#endif
|