opencv-python中图像倾斜检测的代码



如何使用OpenCV c++将图像中的偏斜检测和校正代码转换为OpenCV python。我试图转换以下代码,但它不起作用。

Mat src=imread("text.png",0);
Mat thr,dst;
threshold(src,thr,200,255,THRESH_BINARY_INV);
imshow("thr",thr);
std::vector<cv::Point> points;
cv::Mat_<uchar>::iterator it = thr.begin<uchar>();
cv::Mat_<uchar>::iterator end = thr.end<uchar>();
for (; it != end; ++it)
    if (*it)
        points.push_back(it.pos());
cv::RotatedRect box = cv::minAreaRect(cv::Mat(points));
cv::Mat rot_mat = cv::getRotationMatrix2D(box.center, box.angle, 1);
//cv::Mat rotated(src.size(),src.type(),Scalar(255,255,255));
Mat rotated;
cv::warpAffine(src, rotated, rot_mat, src.size(), cv::INTER_CUBIC);
imshow("rotated",rotated);

*它总是正确的。我认为你应该试试

if (!thr.at<uchar>(it.pos()))

也许是你的错误

相关内容

  • 没有找到相关文章

最新更新