排序坐标从左上到右下

Sort Coordinates from top left to bottom right

本文关键字:坐标 排序      更新时间:2023-10-16

我使用c++和OpenCV从10x11 led阵列的轮廓中提取了110个坐标,并将它们存储在矢量中。现在我想从左上到右下对它们进行排序,以检测某个行和列中的LED是否打开。我将坐标按y轴位置排列,以确保向量中的前10个坐标代表图像中的第一个LED行。

vector<Point2f> centers;
bool compareY(Point2f p1, Point2f p2){
if(p1.y < p2.y) return true;
if(p1.y > p2.y) return false;
}
sort(centers.begin(), centers.end(), compareY);

现在我必须按x位置对它们排序。问题是,从第二行或任何其他行的第一个LED的x位置可以比第一行的第一个LED小一点。由于这个事实,它们必须从中心[0]到中心[9],从中心[10]到中心[20]排序……一行一行地。有人知道怎么做吗?

提前感谢!

编辑:设法对点进行排序,但我的基于轮廓检测的算法不够健壮,无法检测所有led。有没有人想到一个可靠的方法来检测它们?

如果您想按Y坐标和X坐标执行字典排序,您只需要提供一个合适的比较函数,它真正实现了严格的弱排序。例如

#include <tuple>
bool compareYX(const Point2f& p1, const Point2f& p2)
{
  return std::tie(p1.y, p1.x) < std::tie(p2.y, p2.x);
}

还可以手动实现字典顺序比较,但这很容易出错。