opencv怎么利用霍夫變換檢測直線進(jìn)行圖片校正

小編給大家分享一下opencv怎么利用霍夫變換檢測直線進(jìn)行圖片校正,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司專注于梨樹網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供梨樹營銷型網(wǎng)站建設(shè),梨樹網(wǎng)站制作、梨樹網(wǎng)頁設(shè)計、梨樹網(wǎng)站官網(wǎng)定制、重慶小程序開發(fā)公司服務(wù),打造梨樹網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供梨樹網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

利用霍夫變換檢測直線,校正拍攝傾斜的圖片

#include<opencv2\opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
#define ERROR 1234

//度數(shù)轉(zhuǎn)換
double DegreeTrans(double theta)
{
 double res = theta / CV_PI * 180;
 return res;
}

//逆時針旋轉(zhuǎn)圖像degree角度(原尺寸) 
void rotateImage(Mat src, Mat& img_rotate, double degree)
{
 //旋轉(zhuǎn)中心為圖像中心 
 Point2f center;
 center.x = float(src.cols / 2.0);
 center.y = float(src.rows / 2.0);
 int length = 0;
 length = sqrt(src.cols*src.cols + src.rows*src.rows);
 //計算二維旋轉(zhuǎn)的仿射變換矩陣 
 Mat M = getRotationMatrix2D(center, degree, 1);
 warpAffine(src, img_rotate, M, Size(length, length), 1, 0, Scalar(255, 255, 255));//仿射變換,背景色填充為白色 
}

//通過霍夫變換計算角度
double CalcDegree(const Mat &srcImage, Mat &dst)
{
 Mat midImage, dstImage;

 Canny(srcImage, midImage, 50, 200, 3);
 cvtColor(midImage, dstImage, CV_GRAY2BGR);

 //通過霍夫變換檢測直線
 vector<Vec2f> lines;
 HoughLines(midImage, lines, 1, CV_PI / 180, 300, 0, 0);//第5個參數(shù)就是閾值,閾值越大,檢測精度越高
 //cout << lines.size() << endl;

 //由于圖像不同,閾值不好設(shè)定,因為閾值設(shè)定過高導(dǎo)致無法檢測直線,閾值過低直線太多,速度很慢
 //所以根據(jù)閾值由大到小設(shè)置了三個閾值,如果經(jīng)過大量試驗后,可以固定一個適合的閾值。

 if (!lines.size())
 {
  HoughLines(midImage, lines, 1, CV_PI / 180, 200, 0, 0);
 }
 //cout << lines.size() << endl;

 if (!lines.size())
 {
  HoughLines(midImage, lines, 1, CV_PI / 180, 150, 0, 0);
 }
 //cout << lines.size() << endl;
 if (!lines.size())
 {
  cout << "沒有檢測到直線!" << endl;
  return ERROR;
 }
 float sum = 0;
 //依次畫出每條線段
 for (size_t i = 0; i < lines.size(); i++)
 {
  float rho = lines[i][0];
  float theta = lines[i][1];
  Point pt1, pt2;
  //cout << theta << endl;
  double a = cos(theta), b = sin(theta);
  double x0 = a*rho, y0 = b*rho;
  pt1.x = cvRound(x0 + 1000 * (-b));
  pt1.y = cvRound(y0 + 1000 * (a));
  pt2.x = cvRound(x0 - 1000 * (-b));
  pt2.y = cvRound(y0 - 1000 * (a));
  //只選角度最小的作為旋轉(zhuǎn)角度
  sum += theta;
  line(dstImage, pt1, pt2, Scalar(55, 100, 195), 1, CV_AA); //Scalar函數(shù)用于調(diào)節(jié)線段顏色
  imshow("直線探測效果圖", dstImage);
 }
 float average = sum / lines.size(); //對所有角度求平均,這樣做旋轉(zhuǎn)效果會更好
 cout << "average theta:" << average << endl;
 double angle = DegreeTrans(average) - 90;
 rotateImage(dstImage, dst, angle);
 //imshow("直線探測效果圖2", dstImage);
 return angle;
}

void ImageRecify(const char* pInFileName, const char* pOutFileName)
{
 double degree;
 Mat src = imread(pInFileName);
 imshow("原始圖", src);
 int srcWidth, srcHight;
 srcWidth = src.cols;
 srcHight = src.rows;
 cout << srcWidth << " " << srcHight << endl;
 Mat dst;
 src.copyTo(dst);
 //傾斜角度矯正
 degree = CalcDegree(src, dst);
 if (degree == ERROR)
 {
  cout << "矯正失??!" << endl;
  return;
 }
 rotateImage(src, dst, degree);
 cout << "angle:" << degree << endl;
 imshow("旋轉(zhuǎn)調(diào)整后", dst);

 Mat resulyImage = dst(Rect(0, 0, srcWidth, srcHight)); //根據(jù)先驗知識,估計好文本的長寬,再裁剪下來
 imshow("裁剪之后", resulyImage);
 imwrite("recified.jpg", resulyImage);
}


int main()
{
 ImageRecify("jiao.jpg", "FinalImage.jpg");
 waitKey();
 return 0;
}

效果圖如下所示:

opencv怎么利用霍夫變換檢測直線進(jìn)行圖片校正

opencv怎么利用霍夫變換檢測直線進(jìn)行圖片校正

opencv怎么利用霍夫變換檢測直線進(jìn)行圖片校正

opencv怎么利用霍夫變換檢測直線進(jìn)行圖片校正

以上是“opencv怎么利用霍夫變換檢測直線進(jìn)行圖片校正”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享文章:opencv怎么利用霍夫變換檢測直線進(jìn)行圖片校正
當(dāng)前URL:http://bm7419.com/article36/pscpsg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計公司、網(wǎng)站建設(shè)全網(wǎng)營銷推廣、移動網(wǎng)站建設(shè)、電子商務(wù)、網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化