У меня возникают проблемы с вращением. Я хочу сделать следующее:
- Поворот изображения
- Обнаружение функций на повернутом изображении (точках)
- Поверните назад точки, чтобы я мог иметь координаты точек, соответствующие исходному изображению
Я немного застрял на третьем шаге.
Мне удалось повернуть изображение с помощью следующего кода:
cv::Mat M(2, 3, CV_32FC1);
cv::Point2f center((float)dst_img.rows / 2.0f, (float)dst_img.cols / 2.0f);
M = cv::getRotationMatrix2D(center, rotateAngle, 1.0);
cv::warpAffine(dst_img, rotated, M, cv::Size(rotated.cols, rotated.rows));
Я пытаюсь повернуть назад точки с помощью этого кода:
float xp = r.x * std::cos( PI * (-rotateAngle) / 180 ) - r.y * sin(PI * (rotateAngle) / 180);
float yp = r.x * sin(PI * (-rotateAngle) / 180) + r.y * cos(PI * (rotateAngle) / 180);
Это не значит, что вы работаете, но точки не возвращаются на изображение. Существует смещение.
Спасибо за помощь