0

我已将 Eclipse CDT 更新到 9.8.1,语法检查器开始指出一些并非如此的错误。在此示例中,p3Dw并且Owcv::Mat对象,语法检查器下划线PO为“无效参数”:

cv::Mat PO = p3Dw-Ow;


Invalid arguments '
Candidates are:
 Mat()
 Mat(int, int, int)
 Mat(int, int, int, const cv::Scalar_<double> &)
 Mat(cv::Size_<int>, int)
 Mat(cv::Size_<int>, int, const cv::Scalar_<double> &)
 Mat(int, const int *, int)
 Mat(int, const int *, int, const cv::Scalar_<double> &)
 Mat(const std::vector<int,std::allocator<int>> &, int)
 Mat(const std::vector<int,std::allocator<int>> &, int, const cv::Scalar_<double> &)
 Mat(const cv::Mat &)
 Mat(int, int, int, void *, unsigned long int)
 Mat(cv::Size_<int>, int, void *, unsigned long int)
 Mat(const std::vector<#0,std::allocator<#0>> &, bool)
 Mat(std::initializer_list<#0>)
 Mat(std::initializer_list<int>, std::initializer_list<#0>)
 Mat(const std::array<#0,unsigned long int3 #1 0> &, bool)
 Mat(const cv::Vec<#0,int3 #1 0> &, bool)
 Mat(const cv::Matx<#0,int3 #1 0,int3 #2 0> &, bool)
 Mat(const cv::Point_<#0> &, bool)
 Mat(const cv::Point3_<#0> &, bool)
 Mat(const cv::MatCommaInitializer_<#0> &)
 Mat(const cv::Mat &, const cv::Range &, const cv::Range &)
 Mat(const cv::Mat &, const cv::Rect_<int> &)
 Mat(const cv::Mat &, const cv::Range *)
 Mat(const cv::Mat &, const std::vector<cv::Range,std::allocator<cv::Range>> &)
 Mat(cv::Mat &&)
 Mat(int, const int *, int, void *, const unsigned long int *)
 Mat(const std::vector<int,std::allocator<int>> &, int, void *, const unsigned long int *)
 Mat(const cv::cuda::GpuMat &)
'

它仅在使用 MatExpr 在声明时分配 Mat 时发生。否则不会发生:您可以声明一个 Mat 分配另一个 Mat,或将一个 MatExpr 分配给先前声明的 Mat。

这段代码已经工作了多年。现在我正在搞乱它,我将无法编译它一段时间。

我清理了项目并重建了索引,没有任何改进。

还有其他奇怪的误导性错误。使用命名空间标准;检查标记向量和 unique_lock 为错误,除非我添加 std::

有什么想法吗?谢谢你。

4

1 回答 1

3

文档中有自由函数MatExpr operator-(const Mat &a, const Mat &b);函数和赋值运算符Mat& Mat::operator=(const MatExpr &expr);opencv4但没有Mat构造函数接受MatExpr.

但是有一个转换运算符:cv::MatExpr::operator Mat() const;应该使您的代码工作,并且它在 opencv 3.4.4 中工作最小的例子:

#include <opencv2/core/mat.hpp> // it is really opencv 3.4.4

int main() {
    cv::Mat p3Dw;
    cv::Mat Ow;
    cv::Mat PO = p3Dw-Ow;
}

如果它在 opencv 4 中不起作用,他们可能已经创建了复制构造函数explicit(即使它不在手册中)。如果是这样,请将其MatExpr转换为Mat

cv::Mat PO = static_cast<cv::Mat>(p3Dw-Ow);
于 2019-08-08T14:07:46.693 回答