opencv檢測(cè)直線方法之投影法
本文實(shí)例為大家分享了opencv檢測(cè)直線之投影法的具體代碼,供大家參考,具體內(nèi)容如下
以下是我對(duì)投影法的一點(diǎn)認(rèn)識(shí)和實(shí)驗(yàn):
投影法就是數(shù)字圖像在某個(gè)方向上進(jìn)行像素累加。通過(guò)水平和垂直方向的投影,可以得到表格圖像投影的幾個(gè)特點(diǎn):
(1)表格區(qū)域的水平與豎直投影分布通常出現(xiàn)周期性的尖峰
(2)在文字投影的行與行之間或列與列之間常會(huì)出現(xiàn)明顯的空白區(qū)
因此,求圖像水平以及豎直投影,根據(jù)特點(diǎn)分別設(shè)以閾值就可以將橫線以及豎直線所在位置確定。
第一步:求圖像的水平投影、豎直投影
第二步:設(shè)定合理閾值,求取大于閾值的坐標(biāo)(水平投影記錄縱坐標(biāo),垂直投影記錄橫坐標(biāo))
第三步:根據(jù)記錄縱坐標(biāo)恢復(fù)水平線,根據(jù)記錄橫坐標(biāo)恢復(fù)豎直線。
下面附整體代碼以及實(shí)驗(yàn)結(jié)果:
#include<iostream> #include<vector> #include <cv.h> #include <highgui.h> using namespace std; using namespace cv; Mat VerticalLine(Mat srcImageBin)//垂直線條檢測(cè) { vector <int> array;//動(dòng)態(tài)數(shù)組用來(lái)存儲(chǔ)投影值大于閾值的橫坐標(biāo) int *colswidth = new int[srcImageBin.cols]; //申請(qǐng)src.image.cols個(gè)int型的內(nèi)存空間,存儲(chǔ)二值圖中每列的白色像素?cái)?shù) memset(colswidth, 0, srcImageBin.cols * 4); //數(shù)組必須賦初值為零,否則出錯(cuò)。無(wú)法遍歷數(shù)組。 int value; for (int i = 0; i < srcImageBin.cols; i++) { for (int j = 0; j < srcImageBin.rows; j++) { value = srcImageBin.at<uchar>(j, i); if (value == 255) { colswidth[i]++; //統(tǒng)計(jì)每列的白色像素點(diǎn) } } } Mat lineImage(srcImageBin.rows, srcImageBin.cols, CV_8UC1, cv::Scalar(0, 0, 0)); //尋找投影大于閾值0.3*srcImageBin.rows的橫坐標(biāo) for (int i = 0; i < srcImageBin.cols; i++) { bool flag = true; for (int j = 0; j < colswidth[i] && colswidth[i] >= (0.3*srcImageBin.rows); j++) { if (flag == true) { array.push_back(i); flag = false; } } } int count = array.size(); //恢復(fù)直線 for (int n = 0; n < srcImageBin.rows; n++) { for (int w = 0; w<count; w++) { if (srcImageBin.at<uchar>(n, array[w]) == 255) { lineImage.at<uchar>(n, array[w]) = 255; } } } delete[] colswidth; return lineImage; } Mat HorizonLine(Mat srcImageBin)//水平線條檢測(cè) { vector <int> array1; int *rowswidth = new int[srcImageBin.rows]; memset(rowswidth, 0, srcImageBin.rows * 4); int value; for (int i = 0; i < srcImageBin.rows; i++) { for (int j = 0; j < srcImageBin.cols; j++) { value = srcImageBin.at<uchar>(i, j); if (value == 255) { rowswidth[i]++; //統(tǒng)計(jì)每行的白色像素點(diǎn) } } } Mat lineImage(srcImageBin.rows, srcImageBin.cols, CV_8UC1, cv::Scalar(0, 0, 0)); //尋找投影大于閾值0.525*srcImageBin.cols的縱坐標(biāo) for (int i = 0; i < srcImageBin.rows; i++) { bool flag = true; for (int j = 0; j < rowswidth[i] && rowswidth[i] >= (0.525*srcImageBin.cols); j++) { if (flag == true) { array1.push_back(i); flag = false; } } } int count = array1.size(); //恢復(fù)水平線 for (int h = 0; h<count; h++) { for (int m = 0; m < srcImageBin.cols; m++) { if (srcImageBin.at<uchar>(array1[h], m) == 255) { lineImage.at<uchar>(array1[h], m) = 255; } } } delete[] rowswidth;//釋放前面申請(qǐng)的空間 return lineImage; } int main() { Mat srcImage = imread("E:\\x.jpg"); Mat closeimage; imshow("原圖", srcImage); if (srcImage.channels() > 1) cvtColor(srcImage, srcImage, CV_RGB2GRAY); Mat srcImageBin; threshold(srcImage, srcImageBin, 140, 255, CV_THRESH_OTSU | CV_THRESH_BINARY_INV); Mat VP; VP = VerticalLine(srcImageBin); Mat HP; HP = HorizonLine(srcImageBin); Mat mergelineImage; bitwise_or(HP, VP, mergelineImage); imshow("mergelineImage", mergelineImage); waitKey(0); return 0; }
實(shí)驗(yàn)結(jié)果如下:
由上結(jié)果可知,如果直線中間有字會(huì)被誤檢為直線,圖中用紅色橢圓標(biāo)出。
文中若有錯(cuò)誤的不妥的地方,還望指出,以便共同學(xué)習(xí)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:Opencv Hough算法實(shí)現(xiàn)圖片中直線檢測(cè)
欄 目:C語(yǔ)言
下一篇:C/C++新建注冊(cè)表項(xiàng)的代碼示例
本文標(biāo)題:opencv檢測(cè)直線方法之投影法
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/556.html
您可能感興趣的文章
- 01-10Unix下C程序內(nèi)存泄漏檢測(cè)工具Valgrind的安裝與使用詳解
- 01-10C語(yǔ)言中的內(nèi)存泄露 怎樣避免與檢測(cè)
- 01-10C++內(nèi)存泄漏及檢測(cè)工具詳解
- 01-10使用dc畫(huà)筆畫(huà)矩形、直線與橢圓示例
- 01-10實(shí)現(xiàn)opencv圖像裁剪分屏顯示示例
- 01-10使用opencv拉伸圖像擴(kuò)大分辨率示例
- 01-10C++程序檢測(cè)內(nèi)存泄漏的方法分享
- 01-10基于C++實(shí)現(xiàn)kinect+opencv 獲取深度及彩色數(shù)據(jù)
- 01-10for循環(huán)中刪除map中的元素valgrind檢測(cè)提示error:Invalid read of size
- 01-10淺談CMake配置OpenCV 時(shí)靜態(tài)鏈接與動(dòng)態(tài)鏈接的選擇


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫(xiě)分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫(xiě)函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒(méi)有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 04-02jquery與jsp,用jquery
- 01-10delphi制作wav文件的方法