黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

(轉(zhuǎn)載)Python圖像處理(7):利用輪廓分塊處理

系統(tǒng) 2057 0

快樂蝦

http://blog.csdn.net/lights_joy/

歡迎轉(zhuǎn)載,但請(qǐng)保留作者信息


在得到綠色植物的前景圖像后,我們希望能夠進(jìn)一步標(biāo)識(shí)出其中的棉花植株和雜草。測(cè)試圖像仍然是它:

(轉(zhuǎn)載)Python圖像處理(7):利用輪廓分塊處理_第1張圖片


首先要做的當(dāng)然是對(duì)圖像進(jìn)行分區(qū)域處理。在上一步中我們得到了標(biāo)識(shí)綠色植物的二值圖像,一個(gè)很自然的想法是利用此二值圖像的輪廓進(jìn)行分塊。


[python] view plain copy
  1. #?獲取輪廓,我們的目的是分塊,因此只使用外層輪廓,使用點(diǎn)序列的形式 ??
  2. bin_img_save?=?np.copy(bin_img)??
  3. (contoures,?hierarchy)?=?cv2.findContours(bin_img_save,?cv2.RETR_EXTERNAL,?cv2.CHAIN_APPROX_NONE)??

這里需要注意的是,在使用 findContours 函數(shù)前必須將圖像復(fù)制一份,否則此函數(shù)將改變傳入的圖像數(shù)據(jù)。


計(jì)算的結(jié)果居然有 49 個(gè)區(qū)域,對(duì)于太小的區(qū)域其實(shí)我們并不關(guān)心,我們計(jì)算區(qū)域面積并從大到小進(jìn)行排序。 OpenCV 提供了兩個(gè)排序函數(shù), sort sortIdx ,其中 sort 可以得到排序后的值數(shù)組,而 sortIdx 能夠得到這些值在原數(shù)組中的序號(hào),因而這里使用 sortIdx

[python] view plain copy
  1. #?按面積排序 ??
  2. areas?=?np.zeros(?len(contoures)?)??
  3. idx?=? 0 ??
  4. for ?cont? in ?contoures?:???
  5. ????areas[idx]?=?cv2.contourArea(cont)??
  6. ????idx?=?idx?+? 1 ??
  7. areas_s?=?cv2.sortIdx(areas,?cv2.SORT_DESCENDING?|?cv2.SORT_EVERY_COLUMN)??

然后處理面積大于 100 的區(qū)域:

[python] view plain copy
  1. (b8,?g8,?r8)?=?cv2.split(src)??
  2. ??
  3. #?對(duì)每個(gè)區(qū)域進(jìn)行處理 ??
  4. for ?idx? in ?areas_s?:??
  5. ???? if ?areas[idx]?<? 100 ?:??
  6. ???????? break ??
  7. ??
  8. ???? #?繪制區(qū)域圖像,通過將thickness設(shè)置為-1可以填充整個(gè)區(qū)域,否則只繪制邊緣 ??
  9. ????poly_img?=?np.zeros(?bin_img.shape,?dtype?=?np.uint8?)??
  10. ????cv2.drawContours(poly_img,?contoures,?idx,?[ 255 , 255 , 255 ],?- 1 )??
  11. ????poly_img?=?poly_img?&?bin_img??
  12. ??
  13. ???? #?得到彩色的圖像 ??
  14. ????color_img?=?cv2.merge([b8?&?poly_img,?g8?&?poly_img,?r8?&?poly_img])??
  15. ??
  16. ????cv2.imshow( 'poly_img' ,?color_img)??
  17. ????cv2.waitKey()??

目前我們僅僅是顯示這塊區(qū)域的彩色圖像。最后得到這樣的結(jié)果:

(轉(zhuǎn)載)Python圖像處理(7):利用輪廓分塊處理_第2張圖片

(轉(zhuǎn)載)Python圖像處理(7):利用輪廓分塊處理_第3張圖片


我們需要正確標(biāo)識(shí)這兩塊區(qū)域是棉花還是雜草。




更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論