c++ - 使用较少的 STL 运算符对点进行排序

标签 c++ qt sorting opencv stl

我想对来自 openCV Blob 检测的 110 个关键点进行排序,从上到下,从左到右。但有时会出错。

bool sortRects(const Rect &a, const Rect &b)
{
return ( (a.x + a.y*10) < (b.x + b.y*10) );
}

   vector<Rect> convertedKeyPoints;

   for(int i = 0; i < detectedLedPositions.size(); i++)
   {
   Point2f point(detectedLedPositions[i].pt.x+1.f, detectedLedPositions[i].pt.y + 1.f);
   Rect keyPointToRect(detectedLedPositions[i].pt, point);
   convertedKeyPoints.push_back(keyPointToRect);
   }

   sort(convertedKeyPoints.begin(), convertedKeyPoints.end(), sortRects);

 for(int i = 0; i < convertedKeyPoints.size(); i++)
        {
            QPointF currentPoint(QPoint(convertedKeyPoints[i].tl().x , convertedKeyPoints[i].tl().y));
            ledPosition.push_back(currentPoint);
        }

这是将 转换为 QPointF 后调试控制台的输出。

QPointF(133, 138)
QPointF(188, 134)
QPointF(240, 134)
QPointF(290, 135)
QPointF(347, 142)
QPointF(454, 137)
QPointF(398, 144)
QPointF(507, 136)
QPointF(27, 189)
QPointF(191, 191)
**QPointF(138, 199)**
QPointF(244, 191)
QPointF(293, 194)
QPointF(345, 189)
QPointF(400, 194)
QPointF(451, 190)
QPointF(505, 192)

那我做错了什么?

最佳答案

我认为您的排序操作假设 a.x<10,但在您的示例中并非如此。

尝试:

bool sortRects(const Rect &a, const Rect &b)
{
  return a.y == b.y ? a.x < b.x : a.y < b.y;
}

这将首先在 Y 轴上排序(从上到下),在两者完全相等的情况下,将返回到在 X 轴上排序(从左到右)。

关于c++ - 使用较少的 STL 运算符对点进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29244129/

相关文章:

java - Java 中的最小/最大 lambda 表达式

javascript - 另一个 javascript 数组字母排序困难

c++ - 我试图在 char 数组的中间添加一个空格。不确定如何正确移动它

python - 如何在 qt 应用程序上使用 cv2.waitKey 使用 'p' 键暂停和播放

javascript - qml 函数的默认参数给出语法错误

android - 进程 "...androiddeployqt.exe"以代码 14 退出

java - 在 Java 中手动排序链表(词法)

c++ - GLFW undefined reference 很多东西

c++ - 反对异常(exception)

c++ - 如何正确初始化一个对象。 [C++]