Ваш вопрос может сбить с толку. Как это может быть (1) сортировать расстояние до круга в левом верхнем углу изображения. (2) отсортировать расстояние от левого верхнего края каждого кружка до левого верхнего угла изображения?
Я предполагаю, что вы хотите найти круг, который наиболее близок к верхнему левому регистру (1).
Вот мой ответ.
Из примера C ++ (я полагаю, вы используете Android, не очень знакомый). Вы можете конвертировать, используя мой пример кода ниже.
for( size_t i = 0; i < circles.size(); i++ )
{
Point center(cvRound(circles[i][0]), cvRound(circles[i][1]));
int radius = cvRound(circles[i][2]);
// circle center
circle( src, center, 3, Scalar(0,255,0), -1, 8, 0 );
// circle outline
circle( src, center, radius, Scalar(0,0,255), 3, 8, 0 );
}
центр должен быть точкой, которую вы хотите.
Чтобы отсортировать их слева направо, используя расстояние от городских кварталов, вам нужно просто набрать
void sort_points (std::vector<Vec3f> &array)
{
std::cout<<"Elements in the array: "<<array.size()<<std::endl;
//comparisons will be done n times
for (int i = 0; i < array.size(); i++)
{
//compare elemet to the next element, and swap if condition is true
for(int j = 0; j < array.size() - 1; j++)
{
if ((array[j][0]+array[j][1]) > (array[j+1][0]+ array[j+1][1])
Swap(&array[j], &array[j+1]);
}
}
}
int main(argc,argv)
// ...................//do your stuff
vector<Vec3f> circles; //detected circle
// ... //do the detection
sort_points(circles);
//circles here is fully sorted from city block distance
std::cout<<circles<<std::endl; // print out all sorted circile
// ...................//do your stuff
}
если это 2-й случай, просто измените, если на
if ((array[j][0]+array[j][1]-2*array[j][2]) > (array[j+1][0]+ array[j+1][1]-2*array[j+1][2])