快樂蝦
http://blog.csdn.net/lights_joy/
歡迎轉載,但請保留作者信息
在得到綠色植物的前景圖像后,我們希望能夠進一步標識出其中的棉花植株和雜草。測試圖像仍然是它:
首先要做的當然是對圖像進行分區域處理。在上一步中我們得到了標識綠色植物的二值圖像,一個很自然的想法是利用此二值圖像的輪廓進行分塊。
- #?獲取輪廓,我們的目的是分塊,因此只使用外層輪廓,使用點序列的形式 ??
- bin_img_save?=?np.copy(bin_img)??
- (contoures,?hierarchy)?=?cv2.findContours(bin_img_save,?cv2.RETR_EXTERNAL,?cv2.CHAIN_APPROX_NONE)??
這里需要注意的是,在使用 findContours 函數前必須將圖像復制一份,否則此函數將改變傳入的圖像數據。
計算的結果居然有 49 個區域,對于太小的區域其實我們并不關心,我們計算區域面積并從大到小進行排序。 OpenCV 提供了兩個排序函數, sort 和 sortIdx ,其中 sort 可以得到排序后的值數組,而 sortIdx 能夠得到這些值在原數組中的序號,因而這里使用 sortIdx 。
- #?按面積排序 ??
- areas?=?np.zeros(?len(contoures)?)??
- idx?=? 0 ??
- for ?cont? in ?contoures?:???
- ????areas[idx]?=?cv2.contourArea(cont)??
- ????idx?=?idx?+? 1 ??
- areas_s?=?cv2.sortIdx(areas,?cv2.SORT_DESCENDING?|?cv2.SORT_EVERY_COLUMN)??
然后處理面積大于 100 的區域:
- (b8,?g8,?r8)?=?cv2.split(src)??
- ??
- #?對每個區域進行處理 ??
- for ?idx? in ?areas_s?:??
- ???? if ?areas[idx]?<? 100 ?:??
- ???????? break ??
- ??
- ???? #?繪制區域圖像,通過將thickness設置為-1可以填充整個區域,否則只繪制邊緣 ??
- ????poly_img?=?np.zeros(?bin_img.shape,?dtype?=?np.uint8?)??
- ????cv2.drawContours(poly_img,?contoures,?idx,?[ 255 , 255 , 255 ],?- 1 )??
- ????poly_img?=?poly_img?&?bin_img??
- ??
- ???? #?得到彩色的圖像 ??
- ????color_img?=?cv2.merge([b8?&?poly_img,?g8?&?poly_img,?r8?&?poly_img])??
- ??
- ????cv2.imshow( 'poly_img' ,?color_img)??
- ????cv2.waitKey()??
目前我們僅僅是顯示這塊區域的彩色圖像。最后得到這樣的結果:
我們需要正確標識這兩塊區域是棉花還是雜草。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
