我在这里使用Arjun Comar版本的OpenCV 3.0 https://github.com/arjuncomar/opencv…Arjun Comar更新了这个版本的OpenCV,为所有OpenCV函数自动生成C包装器,所以没有良好的c++ FFI的语言仍然可以为OpenCV创建包装器。c++的C包装器位于文件opencv_generated.cpp(必须从上面链接的Arjun Comar OpenCV版本构建,但我将当前版本粘贴在这里http://www.heypasteit.com/clip/17SI和matt .cpp rect.cpp point.cpp和size.cpp位于这里https://github.com/arjuncomar/opencv/tree/master/modules/c/src
在那个版本中,他使用标量指针('Scalar*')来代替所有需要'cv::Scalar(val1 val2 val3 val4)'的函数。唯一的问题是,他没有创建一个create Scalar函数,也没有创建一个Scalar*的替代函数。我的尝试如下,它没有编译
cpp
Scalar* cv_create_Scalar(double val0, double val1, double val2, double val3)
{
//also tried cv:;Scalar - same error
return Scalar(val0, val1, val2, val3);
}
的进行'Scalar* cv_create_Scalar(double val0, double val1, double val2, double val3);'
在Ubuntu的cpp目录下编译
'g++ -Wall -shared -fPIC -o opencv-glue.so opencv-glue.cpp'
但是我得到了这个错误
opencv-glue.cpp: In function ‘cv::Scalar* cv_create_Scalar
(double, double, double, double)’:
opencv-glue.cpp:28:41: error: cannot convert
‘cv::Scalar’ to ‘cv::Scalar* {aka cv::Scalar_<double>*}’ in return
return Scalar(val0, val1, val2, val3);
^
opencv-glue.cpp:30:1: warning: control reaches end of
non-void function [-Wreturn-type]
}
我知道这不是编译函数…它经过了很好的测试,但我需要一个标量*来传递给我创建的函数(它编译正确)
Mat* cv_create_Mat_S(Size* size, int type, Scalar* s) {
return new Mat(*size, type, *s);
}
所以我将有一个标量传递给'absdiff'函数c包装Arjun Comar创建的:
void cv_absdiff(Mat* src1, Mat* src2, Mat* dst) {
cv::absdiff(*src1, *src2, *dst);
}
任何帮助都非常感谢=)
显然,由于转换,它不能编译,但是你不能动态地创建新的标量吗?你只需要记住,这些内存必须通过delete来释放。
Scalar* cv_create_Scalar(double val0, double val1, double val2, double val3)
{
//also tried cv:;Scalar - same error
return new Scalar(val0, val1, val2, val3);
}
如果你想返回一个指向这个对象的指针,就必须这样做。您不能通过创建副本来返回新对象,您必须更改方法签名。