日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

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

系統(tǒng) 1850 0

快樂蝦

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

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


在得到綠色植物的前景圖像后,我們希望能夠進一步標識出其中的棉花植株和雜草。測試圖像仍然是它:

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


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


[python] view plain copy
  1. #?獲取輪廓,我們的目的是分塊,因此只使用外層輪廓,使用點序列的形式 ??
  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ù)。


計算的結(jié)果居然有 49 個區(qū)域,對于太小的區(qū)域其實我們并不關(guān)心,我們計算區(qū)域面積并從大到小進行排序。 OpenCV 提供了兩個排序函數(shù), sort sortIdx ,其中 sort 可以得到排序后的值數(shù)組,而 sortIdx 能夠得到這些值在原數(shù)組中的序號,因而這里使用 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. #?對每個區(qū)域進行處理 ??
  4. for ?idx? in ?areas_s?:??
  5. ???? if ?areas[idx]?<? 100 ?:??
  6. ???????? break ??
  7. ??
  8. ???? #?繪制區(qū)域圖像,通過將thickness設(shè)置為-1可以填充整個區(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張圖片


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




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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 措美县| 日土县| 伊吾县| 根河市| 阿瓦提县| 蓬安县| 安庆市| 盖州市| 定襄县| 博罗县| 将乐县| 古交市| 台东市| 汝州市| 临桂县| 高唐县| 乌拉特前旗| 信丰县| 虎林市| 含山县| 烟台市| 凤翔县| 玛曲县| 泰州市| 个旧市| 巴里| 武威市| 亚东县| 武汉市| 长泰县| 天峻县| 望都县| 武汉市| 鹤岗市| 永清县| 定南县| 涡阳县| 玉龙| 武鸣县| 荆州市| 安平县|