版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、24 / 29基于OpenCV的圖像輪廓提取的實現(xiàn)軟件工程專業(yè) 學(xué)生:榮臻 指導(dǎo)教師:孔令寅摘 要 OpenCV是近幾年來推出的一個開源的、免費的計算機視覺庫.OpenCV的目標是構(gòu)建一個簡單易用的計算機視覺框架,利用它所包含的函數(shù)幫助開發(fā)人員方便快捷地實現(xiàn)圖像處理和視頻處理。而圖像的輪廓是圖像的一種基本特征,攜帶著一幅圖像大部分的信息,經(jīng)常被應(yīng)用到較高層次的圖像應(yīng)用中。它在圖像分離,圖像識別和圖像壓縮等領(lǐng)域有很廣泛的應(yīng)用,也是圖像處理的基礎(chǔ)。本文首先闡述了OpenCV的特點和結(jié)構(gòu),然后采用一系列的可行性算法來獲取圖像特征參數(shù)并通過各種算子(Sobel算子,Laplace算子,Canny算子)
2、對圖像的灰度進行分析,調(diào)節(jié),用實現(xiàn)對圖像的邊緣檢測和輪廓提取。關(guān)鍵詞 OpenCV 圖像 輪廓提取The realization of the image contour extraction based on OpenCVAbstractOpenCV is launched an open source in recent years.Free computer vision library. OpenCV's goal is to build a simple and easy to use computer vision framework, function to help d
3、evelopers use it contains quick and easy to realize image processing and video processing.And the outline of the image is a basic feature of image, carrying an image, most of the information is often applied to the higher level of the image application.It in image separation, image recognition and i
4、mage compression, and other fields have a wide range of applications, is also the basis of image processing.At first, this paper expounds the characteristics and structure of OpenCV, then a series of the feasibility of the algorithm is used to obtain image feature parameters and through a variety of
5、 operator (Sobel operator, Laplace operator, Canny operator) analysis of image gray level, adjustment, use of image edge detection and contour extraction.Key words OpenCV Image Contour extraction目錄1引言11.1 課題背景11.2 研究的目的與意義11.3可行性分析22 開發(fā)工具與輪廓提取概述32.1 OpenCV32.1.1OpenCV簡介32.1.2OpenCV安裝與環(huán)境搭建32.2邊緣檢測42.
6、2.1邊緣檢測42.2.2邊緣檢測原理52.2.3邊緣檢測算子52.3輪廓提取92.3.1輪廓提取目的92.3.2輪廓提取容93 需求分析103.1系統(tǒng)功能分析103.2系統(tǒng)流程圖104 總體設(shè)計114.1 系統(tǒng)功能要求與說明和實現(xiàn)方法114.2 系統(tǒng)功能模塊115 詳細設(shè)計與實現(xiàn)125.1 圖片提取125.2 圖像邊緣檢測155.3 圖像輪廓提取186 程序界面20總結(jié)與展望24參考文獻25致261引言1.1 課題背景圖像處理在應(yīng)用與科研方面已經(jīng)是一個占據(jù)相當(dāng)重要地位的方向,在人們的生活中也有很廣泛的應(yīng)用,圖像表示直觀且信息豐富,是聲音和文字所不能與的。在圖像處理方面很多軟件公司和科研機構(gòu)都
7、研究了關(guān)于圖像處理的軟件。而OpenCV在計算機視覺的開發(fā)和圖像處理中扮演著重要的角色。它為計算機視覺應(yīng)用開發(fā)提供了靈活、功能強大的開發(fā)接口,使其成為計算機視覺專業(yè)人員所依賴的重要開發(fā)工具。它就被廣泛用在許多應(yīng)用領(lǐng)域、產(chǎn)品和研究成果中。1.2 研究目的與意義圖像處理,就是對圖像信息進行加工來滿足人的視覺心理或應(yīng)用需求的行為。視覺是人類從大自然中獲取信息的最主要的手段。據(jù)資料統(tǒng)計,人類獲取信息時,視覺信息約占60,聽覺信息約占20,其他的如味覺信息、觸覺信息等約占20。可以知道視覺信息對人類的重要性,然后圖像就是人類獲取視覺信息的主要造徑。隨著科學(xué)技術(shù)的發(fā)展和人民生活水平的提高,攝像機的出現(xiàn)和數(shù)
8、字圖像處理技術(shù)的發(fā)展,在如今的數(shù)字化時代中,越來越引起人們的廣泛關(guān)注,數(shù)字圖像處理已經(jīng)成為必備的基礎(chǔ)知識。近年來由于計算機技術(shù)的蓬勃發(fā)展,圖像處理技術(shù)也得到了空前的發(fā)展和應(yīng)用。目前,圖像處理技術(shù)已經(jīng)廣泛應(yīng)用于工業(yè)、軍事、醫(yī)學(xué)、交通、農(nóng)業(yè)、天氣預(yù)報、銀行、超市、重要部門的監(jiān)控報警系統(tǒng)、可視、網(wǎng)絡(luò)傳輸?shù)鹊阮I(lǐng)域,就連人們?nèi)粘I钪械淖耘暮陀螒蛞埠蛨D像處理有密切的關(guān)系。本文主要是對計算機視覺系統(tǒng)的應(yīng)用,圖像輪廓提取技術(shù)進行研究。實現(xiàn)表面缺陷的自動檢測圖像,灰度等級自動分選排序,提高圖像的價值有一個非常重要的作用。而影響檢測整體水平的重要方面之一是缺陷圖像的處理過程,而本文研究的重點圖像輪廓提取技術(shù)是圖
9、像分割、目標區(qū)域識別區(qū)域?qū)嵺`提取等圖像分析處理領(lǐng)域的基礎(chǔ)是非常重要的。用非接觸式,精度高,能夠提供全面的分析識別方法來替代人工視覺,解決圖像表面的模式識別和測量問題,是圖像加工行業(yè)面臨的一大難題,也是值得我們長期探討的科研課題。1.3 可行性分析 技術(shù)上的可行性:系統(tǒng)開發(fā)采用C+語言進行程序設(shè)計,運用OpenCV強大的數(shù)字圖像處理技術(shù),在Windows平臺上設(shè)計圖像邊緣檢測和圖像輪廓提取的圖像處理系統(tǒng),使用VS2012的開發(fā)環(huán)境,利用QT的界面管理,給系統(tǒng)提供了高性能的保障。保障了代碼的質(zhì)量,對代碼模塊有了清晰的管,和對后期代碼的修改和擴展提供了很好的支持。綜上所述,本系統(tǒng)的設(shè)計與開發(fā)在技術(shù)上
10、都是滿足的。經(jīng)濟上的可行性:隨著計算機的超速發(fā)展,計算機如今已是處于高配置,低價格的時代,而本系統(tǒng)的開發(fā),其應(yīng)用在游戲,教育,文藝,工業(yè)等多個領(lǐng)域有著重要的意義。本系統(tǒng)的運行可以代替人工進行很多繁瑣重復(fù)的工作,節(jié)省物力人力和很多資源,大大提高了生產(chǎn)效率。所以在經(jīng)濟上是可行的1。 運行上的可行性:本系統(tǒng)作為一個小型的圖像輪廓提取系統(tǒng),所需資源無論是從硬件方面還是軟件方面都能夠滿足條件,所以在運行上也是可行的。2開發(fā)工具與輪廓提取概述2.1 OpenCV2.1.1 程序流程圖OpenCV 全稱 Open Source Computer Vision Libr
11、ary,是由Inter公司資助的開源計算機視覺庫,它是用C/C+語言編寫的,可以實現(xiàn)圖像處理和計算機視覺中的很多算法,可以運行在Linux/Windows/Mac等操作系統(tǒng)上。由于OpenCV的源代碼是完全開源的,并且編寫高效又簡潔,很多函數(shù)都已經(jīng)匯編最優(yōu)化。所以近些年來在國外的圖像處理和相關(guān)領(lǐng)域中被廣泛的使用,成為了一種流行的圖像處理軟件。主要應(yīng)用領(lǐng)域有:1.人機互動 2.物體識別 3.圖象分割 4.人臉識別 5.動作識別 6.運動跟蹤 7.機器人等。2.1.2 OpenCV安裝與環(huán)境搭建首先把OpenCV正確的配置到VS開發(fā)環(huán)境中
12、。設(shè)置預(yù)先編譯的頭文件的路徑與動態(tài)庫的路徑2。 第一步:安裝OpenCV和環(huán)境變量配置計算機-> 屬性-> 高級系統(tǒng)設(shè)置->環(huán)境變量加入名為OPENCV的變量,值為F:opencvbuild(這里是自己OpenCV安裝路徑),在Path變量后追加;%OPENCV%x86vc11bin(X86是32位系統(tǒng),X64是64位系統(tǒng),vc11是vc2012,vc12是2013)。第二步:在VS2012中新建項目建好工程后,視圖->屬性管理器,右鍵Debug,添加新項目屬性表,新建名為OpenCVx86.Dp的項目屬性表(區(qū)分Release的)
13、。雙擊新建好的OpenCVx86.Dps屬性表,找到 常規(guī) -> VC+目錄 -> 包含目錄 下拉后點開編輯,添加如下幾項F:opencvbuildincludeF:opencvbuildincludeopencvF:opencvbuildincludeopencv2確定后,點開庫目錄,編輯,追加如下2項:F:opencvbuildx86vc11libF:opencvbuildx86vc11staticlib確定后,返回VC+目錄,找到 器 -> 輸入 -> 附加依賴項。第三步:測試是否配置成功將自己所要顯示的圖片放到工程下,新建源文件輸入以
14、下代碼,運行,若看到顯示圖片就說明配置成功了!如果以后有其他新建項目用到OpenCV,只需要在屬性管理器頁面導(dǎo)入以上創(chuàng)建的項目屬性表即可!2.2 邊緣檢測2.2.1 邊緣檢測計算機處理圖像有兩個目的:第一個是產(chǎn)生更加能夠讓人觀察和識別的圖像,第二個是更加能夠讓計算機自動識別和理解圖像3??傊?,最終的目的先對大量的圖像攜帶的信息進行分解,通過處理分解出來的最基本的基元從而來處理圖像。而邊緣檢測是計算機視覺和圖像處理中的基本問題,邊緣檢測的目的則是標識圖像中亮度變化明顯的點。圖像屬性中的顯著變化通常反映了屬性的變化。這些包括(i)深度上的不連續(xù)、(ii)表面方向不連續(xù)、(iii)物質(zhì)屬性變化和(i
15、v)場景照明變化。邊緣檢測是圖像處理和計算機視覺中,尤其是特征提取中的一個研究領(lǐng)域。圖像的邊緣是圖像最基本的特征。圖像邊緣指的是周圍像素灰度有階級跳躍的變化或者屋頂變換的像素的集合。邊緣的種類有兩種,我們通常把它們記作:階躍性邊緣(兩邊的灰度值有顯著的不同)和屋頂狀邊緣(存在于灰度值從增加到減少的變化轉(zhuǎn)折點),那么怎么分辨圖像的邊緣呢?圖像的邊緣其實就是存在在物體與物體,物體與圖像背景之間,這些都是我們能用眼睛看見的,可以從宏觀上這么說。其實基元與基元之間都存在著邊緣,這些是微觀方面的說話。所以這都是圖像要分割,分離的最基本的特征,我們通過尋找邊緣就能分離圖像。邊緣的種類有兩種,我們通常把它們
16、記作:階躍性邊緣(兩邊的灰度值有顯著的不同)和屋頂狀邊緣(存在于灰度值從增加到減少的變化轉(zhuǎn)折點)。下面是幾種類型邊緣的截面圖。圖2-1理想躍階式 圖2-2斜降式 圖2-3斜升式 圖2-4 脈沖式 圖2-5屋頂式2.2.2 邊緣檢測原理通過前面的介紹我們也大概的了解到邊緣檢測的基本概念,我們把邊緣定義為圖像中灰度發(fā)生急劇變化的局域。那么邊緣檢測的原理就能很好的理解,就是用某些已存在的算法來解決我們所要表達的問題,更官方一點的話說就是用算法提取圖像和背景之間的交界線,從而來實現(xiàn)邊緣分離和提取4。邊緣檢測算子其實也就是解決問題的算法,這種算法自然有很多,早期的經(jīng)典算法有邊緣算子法,模擬匹配法,門限法
17、等方法。近些年來隨著人工智能的方法,越來越多的人開始關(guān)注,于是又涌現(xiàn)了很多新的邊緣檢測算法,其中最為人多議論的有小波變換和小波包的邊緣檢測法、基于形態(tài)學(xué)和神經(jīng)網(wǎng)絡(luò)的邊緣檢測法。我們可以來初步了解一下計算機是怎樣檢測圖像邊緣的。就以灰度圖像為例,它的理論基礎(chǔ)是,如果有一個邊緣,那么圖像的灰度就肯定會發(fā)生變化(為了方便假設(shè)由黑漸變?yōu)榘状硪粋€邊界),這時我們可以對其灰度分析,邊緣的灰度函數(shù)就是一個標準一次函數(shù)y=kx+b,我們對其求一階導(dǎo)數(shù)后結(jié)果就是它斜率k,也就是說邊緣的一階導(dǎo)數(shù)是一個常數(shù),而我們又知道由于非邊緣的一階導(dǎo)數(shù)為零,這樣通過求一階導(dǎo)數(shù)就能初步判斷圖像的邊緣了5。下面先來介紹下經(jīng)典的幾
18、種算法。(1)Roberts算子這里介紹一個名詞梯度,我們把梯度定義為一個向量(f),f指出了灰度變化最快的方向和變化量。用公式可以表示為 (2.1) 其中我們可以從以前學(xué)過的數(shù)學(xué)知道它的梯度大小為 (2.2) 梯度的角度為 (2.3) 而這個Roberts算子其實就是對圖像的x(水平方向)和y(垂直方向)來趨近梯度算子。 (2.4) 我們就能得出Roberts算子的表達式為 (2.5)(2)Sobel算子 上面介紹了計算機通過y=kx+b求導(dǎo)數(shù)識別圖像邊緣的,但是在具體圖像中我們會發(fā)現(xiàn)是求不了導(dǎo)數(shù)的,因為沒有準確的函數(shù)公式讓我們來求導(dǎo)數(shù),所以厲害的研究人員就想到了用另一種方式來替換原來的方式
19、求導(dǎo)數(shù)。用一個3×3的二維矩陣窗口對原來圖像進行近似求導(dǎo)。這里拿對x方向求導(dǎo)為例,如下圖2-6,我們定義b2的導(dǎo)數(shù)Ko為第三列的元素(a3,b3,c3)之和減去第一列元素(a1,b1,c1)之和,這樣就求得了b2的近似導(dǎo)數(shù)。我們知道導(dǎo)數(shù)其實就是代表一個變化率,從第一列到第三列,灰度值相減,當(dāng)然就是一個變化率了。當(dāng)然Y方向?qū)?shù)與X方向?qū)?shù)求法相似,就是用第三行元素之和減去第一行元素之和。這樣一來X方向和Y方向?qū)?shù)有了,那么梯度我們也就知道了。 如果這個時候我們給每一列都加一個權(quán)重,分別為1,2,1。這就是Sobel算子了。再舉一例,如圖2-7中,求是不是邊緣點,我們有公式得= (10*
20、1+20*2+30*1)-(30*1+20*2+10*1)=0。由此可知不是邊緣點。圖2-8和圖2-9中的Gx和Gy分別為Sobel算子中水平方向和垂直方向的梯度。圖2-6 矩陣1 圖2-7 矩陣x 圖2-8水平方向梯度 圖2-9 垂直方向梯度(3)Laplace算子 上面介紹的兩個算子都是一階差分算子,而Laplace算子是二階差分算子。我們可以想象為對一個函數(shù)的二次求導(dǎo)。我們可以想象一下,如果圖像中有噪聲(圖像在傳輸過程中的通道傳輸誤差等因素會造成圖像上出現(xiàn)一些隨機的、離散的、孤立的像素點,就是圖像噪聲),噪聲在一階導(dǎo)數(shù)處也會取得極大值從而被當(dāng)作邊緣。如果采用二階導(dǎo)數(shù),這是函數(shù)的極大值點就
21、為0了,我們就可以認為這個點就是圖像的邊緣點了。如下圖2-10為原函數(shù),圖2-11為一階導(dǎo)數(shù),圖2-12為二階導(dǎo)數(shù)。 F(x) F(x) F(x) 圖2-10 原函數(shù) 圖2-11 一階導(dǎo)數(shù) 圖2-12 二階導(dǎo)數(shù) 但是Laplace算子會放大噪聲,所以我們要采用了LOG算子,就是Laplace算子,先對圖像進行高斯模糊,抑制噪聲,再求二階導(dǎo)數(shù),二階導(dǎo)數(shù)為0的地方就是圖像的邊緣。 (4) canny算子 我從一些博客和資料中了解到了canny的原理。我們知道圖像邊緣檢測要滿足兩個條件,一是能有效的抑制噪聲;二是能精確的確定邊緣的位置。然后根據(jù)對信噪比和定位的乘積來進行度量,得到優(yōu)化的算子,這其實就
22、是Canny邊緣檢測算子。類似于Laplace邊緣檢測方法,先平滑后求導(dǎo)數(shù)6。我們來了解一下canny的步驟。 1.消除噪聲;在這一步中,其實就是用高斯平滑濾波器卷積降低噪聲。也就是一個固定值的核。如下圖2-13所示。圖2-13 5核高斯核 2.用一階偏導(dǎo)的有限差分來計算梯度的幅值和方向; 這一步類似于Sobel算子的求X,Y方向上的梯度。圖2-14 水平和垂直方向上的卷積然后使用下列公式,求得梯度的幅度G和方向(一般為0°,45°,90°,135°)。 (2.6)3. 對梯度幅值進行非極大值抑制;g1 g2 d1 C g3 d2 g4經(jīng)過上面的步驟,得
23、到梯度并不能確定邊緣,因此我們應(yīng)該保留局部梯度最大的點,而抑制非極大值。如果圖像梯度幅值矩陣中的元素值越大,說明圖像中該點的梯度值越大,但這不不能說明該點就是邊緣。在Canny算子里面,非極大值抑制是圖像邊緣檢測的最重要的步驟,它的任務(wù)就是尋找像素點局部最大值,將非極大值點所對應(yīng)的灰度值置為0,這樣做就能刪除一大部分的非邊緣的點7。圖2-15 非極大值抑制圖我從一篇博客上了解到了非極大值抑制的工作原理。由上圖2-15可知,要進行非極大值抑制,以圖中c像素點為例,我們首先要知道像素點c的灰度值是否在它的8值鄰域中最大。圖中紅色的線方向我們認為是c像素點的方向,我們就可以認為它局部的最大值是分布在
24、這條線紅色的線上的,而梯度方向的交點d1和d2這兩個像素點的值也可能是局部最大值。綜上可知,我們比較c像素點和這兩像素點的灰度就可以判斷c像素點的灰度值是否在它的8值鄰域中最大。如果c像素點灰度值最小,c像素點不是局部最大灰度值,那么我們就可以認定c像素點不是邊緣8。4.用雙閾值算法檢測和連接邊緣。這一步,Canny 采用了滯后閾值,滯后閾值需要兩個閾值,一般有三種情況作為判定是否為邊緣點,第一如果某個像素點位置的幅值高于高閾值,,則該像素被保留為邊緣像素點。第二如果某個像素點的位置的幅值低于低閾值,則該像素點不是邊緣像素點,移除。如果某個像素點的位置在高閾值和低閾值之間,則該像素點只在被連接
25、到高于高閾值的像素點時才被保留。好吧,我們來看看OpenCV中canny算法。我們還是看看實現(xiàn)函數(shù)和其參數(shù)。void Canny(InputArray image,/輸入圖像,即源圖像OutputArray edges,/輸出邊緣圖像,需要和源圖像一樣的尺寸和類型double threshold1,/第一個滯后性閾值double threshold2,/第而個滯后性閾值int apertureSize=3,/表示應(yīng)用Sobel算子的孔徑大小,其有默認值3bool L2gradient=false);/計算圖像梯度幅值的標識,默認值為false2.3 輪廓提取2.3.1 輪廓提取目的為什么要對圖
26、像進行處理呢,在現(xiàn)實生活中其實都都能多例子,比如為了讓自拍照變得漂亮,為了更清新的看見圖片容,將很多照片的部分拼湊起來變成更好有價值的圖像等等。前面已經(jīng)介紹,利用計算機對圖像進行處理,其目的就是得到更適合人觀察和識別的圖像或者由計算機自動識別和理解的圖像9。提取圖像的基本特征和屬性,用于計算機分析后就能得出自己想要的圖像,圖像的輪廓作為圖像的基本特征,經(jīng)常被應(yīng)用到較高層次的圖像應(yīng)用中去。本論文研究的圖像輪廓提取其實就是實現(xiàn)上述目的的重要的基礎(chǔ)。2.3.2 輪廓提取容圖像輪廓攜帶著圖像大部分信息,而輪廓存在于圖像不規(guī)則的結(jié)構(gòu)和不穩(wěn)定的像素點,當(dāng)然也有的存在于信號的突變處。這些輪廓就是我們在圖像邊
27、緣檢測時重要的條件和因數(shù),所以我們需要對圖像進行邊緣檢測從而提取出圖像的輪廓出來。這些方法或者說是算法都是我們前面說研究過的。有時我們要把自己感興趣的東西從目標圖像中提取出來,一般用到的方法是通過顏色或紋理提取出目標圖像的前景圖,如果這是我們要對前景圖進行分析然后把目標提取出來,這里用到的方法就是提取目標的輪廓10。3需求分析3.1 系統(tǒng)功能分析本文主要是研究的圖像的邊緣處理技術(shù)(邊緣檢測和輪廓提?。┑囊恍┧惴āG懊嫖覀兘榻B了很多經(jīng)典的圖像邊緣檢測的方法,它們是構(gòu)造對像素點灰度階躍變化明顯的微分算子(Sobel算子等)。這種檢測速度是非常喜人的,但是我們得到的圖像結(jié)果一般都是斷斷續(xù)續(xù)的,不怎么
28、完整的結(jié)構(gòu)信息??伤鼈兊膬?yōu)勢在于它們對噪聲非常的敏感,一般這類算法都要對愿圖像進行平滑操作,然后在進行邊緣檢測,這樣一來就能夠檢測出真正的圖像邊緣了。在邊緣檢測技術(shù)中比較靠譜的方法就是線性濾波器,這其實就是Laplace算子。它能很好的解決頻域最優(yōu)化和空域最優(yōu)化之間的矛盾,這類算子的優(yōu)點在于,利用零點檢測中具有各向同性的特點,保證了邊緣的封閉性。這樣處理的圖像會更加符合人眼對圖像的視覺效果。我希望利用所學(xué)的知識,在VS+QT的環(huán)境中來實現(xiàn)它們,進一步的理解它們,能使最后得到的圖像有很好的效果3.2 系統(tǒng)流程圖選取圖像打 開文 件開始圖像處理保存 目標圖像 圖3-1 系統(tǒng)流程圖4總體設(shè)計4.1
29、系統(tǒng)功能要求與說明和實現(xiàn)方法這一部分是介紹系統(tǒng)的實現(xiàn)過程,敘述系統(tǒng)的整體框架。對系統(tǒng)有一個全面的認識,將它的功能和實現(xiàn)方法有全面的了解。在功能上,我們主要有幾個要求,第一整體風(fēng)格要大方一致,結(jié)構(gòu)要清晰合理,實行模塊化管理,界面要清晰,要使用戶一眼就能明白,方面用戶操作。第二要做到開發(fā)的代碼簡潔,便于管理,便于修改,便于擴充。第三,有完善的數(shù)據(jù)的輸入和輸出,容錯性好,不會因為用戶的某個操作造成程序的崩潰,提示多,每一步的操作都很簡單明了,都能提醒用戶與時改正11。實現(xiàn)方法,我采用的是QT5.0+vs2012+OpenCV3.0的框架,選擇QT我看好的是QT5.0是一個跨平臺的C+圖形用戶界面應(yīng)用
30、程序框架,相比原來qt5.0提升了兼容性,更加兼容OpenCV圖像處理和渲染。然而QT Create的出現(xiàn)也方便了我對代碼的編寫,很多一鍵式的操作,給用戶帶來了很多便利。使用QT也就不言而喻了。本系統(tǒng)主要由MyClass類和MyClass.ui類組成。在QT中有QMainWindow提供一個有菜單條、例如工具條和一個狀態(tài)條的主應(yīng)用程序窗口,而正是我們需要的。很直觀的想法是以QMainWindow作為父類派生出MyClass類。在MyClass類中,我們實現(xiàn)了對圖像的提取,圖像格式的轉(zhuǎn)換,圖像的處理,圖像的保存,按鍵監(jiān)聽,信號槽和界面退出等操作12。當(dāng)然也是連接MyClass.ui界面類的。在實
31、現(xiàn)過程中,完成了對MyClass類中,對各個函數(shù)的調(diào)試和修改,對代碼的注釋,對幫助提示框的修改。按鈕與實現(xiàn)功能事件一一對應(yīng),最后對程序進行打包。4.2 系統(tǒng)功能模塊本系統(tǒng)結(jié)構(gòu)分為四個模塊,如圖4-1所示。分別為:文件模塊:對圖片文件的打開,顯示在界面,圖片大小的自適應(yīng),圖片格式轉(zhuǎn)換,保存模塊:對處理后的圖片文件格式轉(zhuǎn)換,保存。邊緣檢測模塊:運用前章節(jié)所介紹的各種算子,進行圖片邊緣檢測。輪廓提取模塊:對圖像輪廓提取。圖像輪廓處理系統(tǒng)輪廓提取邊緣檢測保存圖片圖片提取圖4-1 系統(tǒng)模塊圖下面圖4.2每個子模塊功能圖。 圖片提取讀取圖片 路徑轉(zhuǎn)換圖片格式顯示圖片在UI上圖4-2 圖片提取功能模塊圖 輪
32、廓提取讀取UI上的圖片二值化處理輪廓提取輪廓標記灰度處理 圖4-3各輪廓提取功能模塊圖5詳細設(shè)計5.1 圖片提取這個模塊首先是利用QT Create創(chuàng)建了一個名為MyClass.ui界面類,在類中添加了一個按鈕PushButton。然后利用QT中的信號/槽關(guān)聯(lián)一個事件函數(shù)OpenImageClicked(),在該函數(shù)中實現(xiàn)對圖片的提取。下面為實現(xiàn)代碼。 QString fileName = QFileDialog:getOpenFileName(this,tr("Open Image"), ".",tr("Image Files (*.png
33、*.jpg *.bmp)"); qDebug()<<"filenames:"<<fileName;/彈出對話框,尋找路徑圖片,提取圖片名字。 image = cv:imread(fileName.toLatin1().data();/使用Mat格式 讀取圖片ui->label->setText(fileName); originalimg = image.clone(); /復(fù)制克隆原圖片qimg = MyClass:Mat2QImage(image); /轉(zhuǎn)換圖片格式Mat->Qimage display(qimg);
34、/顯示圖片在UI上來的label上 if(image.data) /根據(jù)圖片的讀取情況判斷按鈕的顯示狀態(tài) ui->pushButton->setEnabled(true);ui->pushButton_2->setEnabled(true); 5.2 圖片邊緣檢測(1)Sobel邊緣算子我們來了解一下Sobel算子在OpenCV中的實現(xiàn)吧。在OpenCV中,用Sobel這個函數(shù)來實現(xiàn)的。 void Sobel ( InputArray src,/輸入圖像 OutputArray dst,/輸出圖像 int ddepth,/輸出圖像的深度 int dx,/x 方向上的差分
35、階數(shù) int dy,/y 方向上的差分階數(shù) int ksize=3,/表示Sobel核的大小(如同上面看見的矩陣),默認值為3 double scale=1,/計算導(dǎo)數(shù)值時可選的縮放因子,默認值為1(沒有應(yīng)用縮放) double delta=0,/表示在結(jié)果存入目標圖像之前可選的delta值,默認值為0 int borderType=BORDER_DEFAULT );/邊界模式,默認值為BORDER_DEFAULT 在這一個模塊中,我依然沿用了UI-MyClass 信號/槽的模式,將UI中的Sobel檢測按鈕與MyClass類中的SobelImageClicked()函數(shù)相關(guān)聯(lián)。然后實現(xiàn)Sob
36、el邊緣檢測。代碼如下。void MyClass:SobelImage(int ,void *)/Sobel實現(xiàn)函數(shù)if(!image.empty()/原圖,原圖的灰度版,目標圖 Mat g_srcImage, g_srcGrayImage,g_dstImage; /Sobel邊緣檢測相關(guān)變量Mat g_sobelGradient_X, g_sobelGradient_Y; Mat g_sobelAbsGradient_X, g_sobelAbsGradient_Y; int g_sobelKernelSize=1;/TrackBar位置參數(shù) g_srcImage =image;/顯示原始圖n
37、amedWindow( "Sobel邊緣檢測", WINDOW_AUTOSIZE ); /顯示處理后的新窗口Sobel(g_srcImage,g_sobelGradient_X,CV_16S, 1, 0, (2*g_sobelKernelSize+1), 1, 1, BORDER_DEFAULT ); / 求 X方向梯度 convertScaleAbs( g_sobelGradient_X, g_sobelAbsGradient_X );/計算絕對值,并將結(jié)果轉(zhuǎn)換成8位 Sobel(g_srcImage,g_sobelGradient_Y,CV_16S, 0, 1, (2*
38、g_sobelKernelSize+1), 1, 1, BORDER_DEFAULT ); / 求Y方向梯度 convertScaleAbs( g_sobelGradient_Y, g_sobelAbsGradient_Y );/計算絕對值,并將結(jié)果轉(zhuǎn)換成8位 addWeighted( g_sobelAbsGradient_X, 0.5, g_sobelAbsGradient_Y, 0.5, 0, g_dstImage ); / 合并X和Y方向的梯度 imshow("Sobel邊緣檢測", g_dstImage); /顯示效果圖 elseQMessageBox:inform
39、ation(this, tr("ERROR!"), tr("please click picture!").arg("");/彈出錯誤提示框 看完代碼和注釋后,我們大概知道了Sobel的實現(xiàn)過程,下面我們來看看測試結(jié)果吧。 圖5-1 sobel邊緣檢測效果圖(2) Laplace邊緣算子現(xiàn)在我們來看看Laplace在OpenCV中是怎樣實現(xiàn)的。void Laplacian(InputArray src,/輸入圖像OutputArray dst,/輸出圖像 int ddepth,/輸出圖像的深度 int ksize=3,/表示Sobel
40、核的大小(如同上面看見的矩陣),默認值為3 double scale=1,/計算導(dǎo)數(shù)值時可選的縮放因子,默認值為1(沒有應(yīng)用縮放) double delta=0,/表示在結(jié)果存入目標圖像之前可選的delta值,默認值為0 int borderType=BORDER_DEFAULT );/邊界模式,默認值為BORDER_DEFAULT我們可以看到在這個Laplacian函數(shù)中和Sobel參數(shù)基本一樣。下面我們來看看效果怎么樣。如圖5-2。圖5-2 Laplace邊緣檢測效果圖(3) Canny邊緣算子這個模塊的實現(xiàn)也是用的上面的模式,簡單明了的實現(xiàn)了Canny邊緣算子的功能。在OpenCV中,C
41、anny的參數(shù)與Laplace算子的參數(shù)差不多,我們來看看實現(xiàn)函數(shù)和其參數(shù)。void Canny(InputArray image,/輸入圖像,即源圖像OutputArray edges,/輸出邊緣圖像,需要和源圖像一樣的尺寸和類型double threshold1,/第一個滯后性閾值double threshold2,/第而個滯后性閾值int apertureSize=3,/表示應(yīng)用Sobel算子的孔徑大小,其有默認值3bool L2gradient=false);/計算圖像梯度幅值的標識,默認值為false下面是實現(xiàn)代碼:void MyClass:CannyImage(int,void *
42、)if(!image.empty()Mat g_srcImage, g_srcGrayImage,g_dstImage; Mat g_cannyDetectedEdges; /canny算子的原圖,二值圖,目標圖的聲明。int g_cannyLowThreshold=20;/canny檢測處理的值,我自己設(shè)置檢測程度。 g_srcImage =image;/獲得UI上的圖片namedWindow( "Canny邊緣檢測", WINDOW_AUTOSIZE);/創(chuàng)建邊緣檢測處理后的新窗口 g_dstImage.create( g_srcImage.size(), g_srcI
43、mage.type() ); /創(chuàng)建與原始圖像同類型和大小的矩陣(dst) cvtColor( g_srcImage, g_srcGrayImage, CV_BGR2GRAY ); / 將原圖像轉(zhuǎn)換為灰度圖像 blur( g_srcGrayImage, g_cannyDetectedEdges, Size(3,3) ); /使用 3x3核來降噪 Canny(g_cannyDetectedEdges,g_cannyDetectedEdges,g_cannyLowThreshold, g_cannyLowThreshold*3, 3 );/使用canny算子處理g_dstImage = Scala
44、r:all(0); g_srcImage.copyTo( g_dstImage, g_cannyDetectedEdges); /復(fù)制處理后的圖像到目標圖像中imshow( "Canny邊緣檢測", g_dstImage ); /顯示目標圖像elseQMessageBox:information(this, tr("ERROR!"), tr("please click picture!").arg("");/彈出幫助提示框下面是原圖和目標圖的對比效果:圖5-3 Canny邊緣檢測效果圖5.3 圖像輪廓提取圖像輪廓到
45、底是什么?有的說輪廓就是一系列的點,也有的說就是圖像中的一條曲線。我們可以根據(jù)不同的表現(xiàn)方法來定義不同的圖像輪廓,就像同多種邊緣算法都能檢測出圖像的邊緣。我了解到在OpenCV中一般是用序列來存儲輪廓信息.序列中的每個元素是就是圖像曲線的一個位置反映.只要簡單把輪廓想象為使用CvSeq表示的一系列的點就可以了。在OpenCV中,我們用FindContours()函數(shù)進行輪廓提取,如下圖5-4,是輪廓提取后的效果圖,可以看到在圖中我們設(shè)定為C為輪廓,H為外輪廓,兩種輪廓,在不同的算子實現(xiàn)方法中,就分別表示輪廓的外邊界和邊界。在OpenCV中我們把得到的輪廓用輪廓樹來表達,從而把包含關(guān)系編碼到樹結(jié)
46、構(gòu)中.這個圖的輪廓樹在根節(jié)點的輪廓叫c0,孔h00和h01是它的字子節(jié)點.這些輪廓中直接包含輪廓稱為他們的子節(jié)點,以此類推.不同的輪廓樹的方式,代表不同的輪廓存儲方式。 A CDE B H00 C0 H01 H0000 C000H0001C0001C000C圖5-4 輪廓解析圖FindContours()是圖像輪廓提取函數(shù),從二值圖像中尋找輪廓FindContours()處理圖像可以是從Canny()函數(shù)得到的有邊緣像素的圖像,或者是從Threshold()與AdaptiveThreshold()得到的圖像。我們的實現(xiàn)方法就是采用的Canny()函數(shù)得到圖像的邊緣?,F(xiàn)在我們來看看OpenCV中
47、FindContours()函數(shù)的參數(shù)。int FindContours( CvArr* image, /image是輸入圖像,圖像必須是8位單通道圖像CvMemStorage* storage,/存存儲器,cvFindContours()找到的輪廓記錄在此存里CvSeq* first_contour,/是指向CvSeq*的一個指針,指向輪廓樹的首地址,int header_size CV_DEFAULT(sizeof(CvContour),/存儲cvFindContours()更多有關(guān)對象分配的信息,可以設(shè)定為sizeof(CvContour)或者sizeof(CvChain),int mo
48、de CV_DEFAULT(CV_RETR_LIST), /計算方法,一般為四種參數(shù):CV_RETR_ExTERNAL, CV_RETR_LIST, CV_RETR_CCOMP或CV_RETR_TREE.mode的值向FindeContours()說明需要的輪廓類型,和希望的放回值形式。int method CV_DEFAULT(CV_CHAIN_APPROX_SIMPLE), /怎么計算CvPoint offset CV_DEFAULT(cvPoint(0,0); 下面是在系統(tǒng)中的實現(xiàn)代碼:void MyClass:FindContours()if(!image.empty()/判斷圖片是否
49、存在RNG rng(12345);int thresh = 100;/輪廓提取值int max_thresh = 255;/輪廓提取最大值 /原圖轉(zhuǎn)換Mat src; Mat src_gray;src = image; /圖片關(guān)聯(lián)cvtColor( src, src_gray, CV_BGR2GRAY );/二值化blur( src_gray, src_gray, Size(3,3) );/除燥 / 創(chuàng)建窗體 namedWindow( "輪廓提取", WINDOW_AUTOSIZE );imshow( "輪廓提取", src );Mat canny_ou
50、tput;/初始化dst/定義點和向量 vector<vector<Point> > contours;vector<Vec4i> hierarchy;Canny( src_gray, canny_output, thresh, thresh*2, 3 );/ 用Canny算子檢測邊緣,當(dāng)然也可以使用其他邊緣算子findContours(canny_output,contours,hierarchy,RETR_TREE,CHAIN_APPROX_SIMPLE, Point(0, 0) );/輪廓查找 / 繪出輪廓 Mat drawing = Mat:zero
51、s( canny_output.size(), CV_8UC3 ); /遍歷所有頂層輪廓,隨機生成顏色值繪制給各連接組成部分for( int i = 0; i< contours.size(); i+ ) Scalar color = Scalar( rng.uniform(0, 255), rng.uniform(0,255), rng.uniform(0,255) ); /繪制填充輪廓 drawContours(drawing,contours, i, color, 2, 8, hierarchy, 0, Point() ); imshow( "輪廓提取", drawing );/ 在窗體中顯示結(jié)果elseQMessageBox:information(this, tr("ERROR!"), tr("please click picture!").arg("");/彈出提取框現(xiàn)在來看下效果,如圖5-5: 圖5-5 輪廓提取效果圖其中可根
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年環(huán)境保護項目合作協(xié)議下載3篇
- 2025年度廠房交易居間與產(chǎn)業(yè)投資顧問合同4篇
- 2025年綠色建筑專業(yè)共建校企合作實施協(xié)議3篇
- 二零二五版廢玻璃回收與節(jié)能玻璃生產(chǎn)合作協(xié)議3篇
- 二零二五版辦公室裝修工程設(shè)計與施工風(fēng)險控制合同2篇
- 2025年水利工程挖掘機施工安全風(fēng)險評估合同3篇
- 2025年度充電樁充電站安全防護設(shè)備采購合同3篇
- 2025年度測繪技術(shù)專利授權(quán)與許可合同樣本4篇
- 第五章《數(shù)據(jù)處理和可視化表達》第1課時《認識大數(shù)據(jù)》 說課稿 2023-2024學(xué)年粵教版(2019)高中信息技術(shù)必修1
- 二零二五版充電樁充電樁充電樁充電樁項目可行性研究報告合同2篇
- 神經(jīng)外科進修匯報課件
- 2024老年人靜脈血栓栓塞癥防治中國專家共識(完整版)
- 騰訊營銷師認證考試題庫(附答案)
- 鄰近鐵路營業(yè)線施工安全監(jiān)測技術(shù)規(guī)程 (TB 10314-2021)
- 四年級上冊脫式計算100題及答案
- 資本市場與財務(wù)管理
- 河南近10年中考真題數(shù)學(xué)含答案(2023-2014)
- 八年級上學(xué)期期末家長會課件
- 2024年大學(xué)試題(宗教學(xué))-佛教文化歷年考試高頻考點試題附帶答案
- HGE系列電梯安裝調(diào)試手冊(ELS05系統(tǒng)SW00004269,A.4 )
- 尤文肉瘤的護理查房
評論
0/150
提交評論