主頁 > 知識庫 > python opencv實現(xiàn)目標(biāo)區(qū)域裁剪功能

python opencv實現(xiàn)目標(biāo)區(qū)域裁剪功能

熱門標(biāo)簽:旅游廁所地圖標(biāo)注怎么弄 宿州電話機器人哪家好 西青語音電銷機器人哪家好 南昌地圖標(biāo)注 無錫智能外呼系統(tǒng)好用嗎 地圖標(biāo)注與注銷 電梯新時達系統(tǒng)外呼顯示e 成都呼叫中心外呼系統(tǒng)哪家強 百應(yīng)電話機器人總部

這個任務(wù)是自己在項目中數(shù)據(jù)處理的一部分內(nèi)容,待處理的圖片如下所示:

我需要將目標(biāo)區(qū)域給裁剪出來,要不然在后期訓(xùn)練網(wǎng)絡(luò)的時候整幅圖像過大,且目標(biāo)區(qū)域過小,得到結(jié)果不好,還會加劇計算量。在網(wǎng)上找了各個大佬的博客看,沒找到合適的,便自己動手寫了,順便自己的小破站剛搭建起來,記錄一下自己的思路。

思路

去尋找目標(biāo)區(qū)域的最左邊,最右邊,最上面和最下面的像素點,取到坐標(biāo)信息以后用CV2的裁剪一下就可以實現(xiàn)了。
#難點
數(shù)據(jù)總共是11952張圖片,每張圖片是1024*768大小的,依次去遍歷的話擔(dān)心太費時間了,結(jié)果還好,圖像中黑色的像素點值為0,計算量比想象的要小很多
#代碼

import cv2

"""
    使用OpenCV截取圖片
"""
def search(path):
    left = 1024
    right = 0
    upper = 768
    lower = 0
    img = cv2.imread(path)[:,:,0]
    # print(img.shape)
    for i in range(768):
        for j in range(1024):
            if img[i,j] != 0 :
                # print(img[i,j])
                left = min(j,left)
                right = max(j,right)
                lower = max(i,lower)
                upper =  min(i,upper)
    return (left,upper,right,lower)

def image_cut_save(path, left, upper, right, lower, save_path):
    """
        所截區(qū)域圖片保存
    :param path: 圖片路徑
    :param left: 區(qū)塊左上角位置的像素點離圖片左邊界的距離
    :param upper:區(qū)塊左上角位置的像素點離圖片上邊界的距離
    :param right:區(qū)塊右下角位置的像素點離圖片左邊界的距離
    :param lower:區(qū)塊右下角位置的像素點離圖片上邊界的距離
     故需滿足:lower > upper、right > left
    :param save_path: 所截圖片保存位置
    """
    img = cv2.imread(path)  # 打開圖像
    cropped = img[upper:lower, left:right]
    # 保存截取的圖片
    cv2.imwrite(save_path, cropped)


if __name__ == '__main__':
    root_path = r'原圖片的路徑'
    save_path = r'裁剪后的圖片保存的路徑'
    images = os.listdir(root_path)
    for image in images:
        # print(image)
        pic_path = os.path.join(root_path,image)
        # print(pic_path)
        pic_save_dir_path = os.path.join(save_path,image)
        print(pic_save_dir_path)
        left, upper, right, lower = search(pic_path)
        # show_cut(pic_path, left, upper, right, lower)
        image_cut_save(pic_path, left, upper, right, lower, pic_save_dir_path)

結(jié)果

裁剪后的圖像如下

到此這篇關(guān)于python opencv實現(xiàn)目標(biāo)區(qū)域裁剪功能的文章就介紹到這了,更多相關(guān)python opencv區(qū)域裁剪內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳解Python+opencv裁剪/截取圖片的幾種方式
  • Python OpenCV實現(xiàn)裁剪并保存圖片
  • python通過opencv實現(xiàn)圖片裁剪原理解析
  • Python實現(xiàn)圖片裁剪的兩種方式(Pillow和OpenCV)
  • Python OpenCV圖像指定區(qū)域裁剪的實現(xiàn)
  • 使用Python和OpenCV檢測圖像中的物體并將物體裁剪下來
  • python opencv對圖像進行旋轉(zhuǎn)且不裁剪圖片的實現(xiàn)方法

標(biāo)簽:許昌 西安 渭南 雅安 贛州 辛集 七臺河 濰坊

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python opencv實現(xiàn)目標(biāo)區(qū)域裁剪功能》,本文關(guān)鍵詞  python,opencv,實現(xiàn),目標(biāo),區(qū)域,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python opencv實現(xiàn)目標(biāo)區(qū)域裁剪功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于python opencv實現(xiàn)目標(biāo)區(qū)域裁剪功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章