我试图去掉一个已知大小元素的图像。鉴于此图片:
我可以使用aruco:: estimatePoseBoard
返回旋转和平移向量。有没有办法利用这些信息来纠正与标记板在同一平面上的所有东西? (不幸的是,我的线性代数充其量只是基本的。)
我知道如何校正标记板。我想要做的是在与标记板相同的平面上去除其他东西(在这种情况下,云形物体)。我试图确定这是否可能,如果可能的话,我该怎么做。我已经可以在我想要去歪斜的对象周围放置四个标记,并使用检测到的角作为getPerspectiveTransform
的输入以及它们之间的已知距离。但对于我们的实际应用,用户可能难以准确地放置标记。如果他们可以在框架中放置一个标记板并让软件去除其他对象,那将会容易得多。
答案 0 :(得分:2)
由于您标记了OpenCV: 从图像中我可以看到你已经检测到所有黑匣子的角落。因此,只需以某种方式获得最多的边界:
然后是这样的:
std::vector<cv::Point2f> src_points={/*Fill your 4 corners here*/};
std::vector<cv::Point2f> dst_points={cv:Point2f(0,0), cv::Point2f(width,0), cv::Point2f(width,height),cv::Point2f(0,height)};
auto H=v::getPerspectiveTransform(src_points,dst_points);
cv::Mat copped_image;
cv::warpPerspective(full_image,copped_image,H,cv::Size(width,height));
答案 1 :(得分:1)
我坚持认为调用getPerspectiveTransform
的目的地点必须是输出图像的角落(因为它们符合Humam的建议)。一旦我意识到目标点可能在输出图像中的某个地方,我得到了答案。
float boardX = 1240;
float boardY = 1570;
float boardWidth = 1730;
float boardHeight = 1400;
vector<Point2f> destinationCorners;
destinationCorners(Point2f(boardX+boardWidth, boardY));
destinationCorners(Point2f(boardX+boardWidth, boardY+boardHeight));
destinationCorners(Point2f(boardX, boardY+boardHeight));
destinationCorners(Point2f(boardX, boardY));
Mat h = getPerspectiveTransform(detectedCorners, destinationCorners);
Mat bigImage(image.size() * 3, image.type(), Scalar(0, 50, 50));
warpPerspective(image, bigImage, h, bigImage.size());
这修正了电路板的视角和平面内的一切。 (电路板的波纹是由于纸张在原始照片中没有平放的原因。)