这是我的OpenCV的MatExpr "/"运算符的C包装
MatExpr* cv_Mat_div_S(Mat* m1, int m2) {
return new MatExpr(*m1 / m2);
}
我想我得到了这部分正确的地方,我将帧转换为指针在cv_Mat_div_S中使用并在cv_Mat_div_S函数
中使用对它的引用 Mat mat(frame);
cv_Mat_div_S(&mat, 255);
但是在尝试使用Cv_Mat_div_S的输出在一个正常的c++ cvtColor如下,我得到一长串的错误,这是最相关的:
错误:' operator* '不匹配(操作数类型为' cv::Mat ')cvtColor(*mat, *mat, CV_BGR2Luv);
这就是我如何试图转换回一个MatExpr:
cvtColor(*mat, *mat, CV_BGR2Luv);
我试过使用&代替*,但不去。
我可以使用帮助将cv_Mat_div_S
的输出转换回MatExpr以在其他c++函数中用于测试…如果有人注意到cv_Mat_div_S
包装器并验证是否有更好的方法来编写它,也许可以接受不止一种类型的value参数…但不用模板因为我要把它编译成。so它应该放在extern C {}
cvtColor()的声明为
void cvtColor( InputArray src, OutputArray dst, int code, int dstCn=0 );
MatExpr可以隐式地转换为_InputArray。但是MatExpr不能隐式地转换为_OutputArray。(参见_InputArray和_OutputArray的源代码)
我尝试测试代码片段:
Mat a0;
MatExpr a(a0);
cvtColor(*(&a), *(&a), COLOR_GRAY2BGR);
VS2012编译错误:
error C2664: 'cv::cvtColor' : cannot convert parameter 2 from 'cv::MatExpr' to 'cv::OutputArray '
所以你需要指定一个有效的OutputArray(例如Mat而不是MatExpr)来保存转换后的Luv图像