濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 利用Python+OpenCV三步去除水印

利用Python+OpenCV三步去除水印

熱門標(biāo)簽:開(kāi)封語(yǔ)音外呼系統(tǒng)代理商 河北防封卡電銷卡 開(kāi)封自動(dòng)外呼系統(tǒng)怎么收費(fèi) 應(yīng)電話機(jī)器人打電話違法嗎 手機(jī)網(wǎng)頁(yè)嵌入地圖標(biāo)注位置 400電話辦理哪種 地圖標(biāo)注線上如何操作 天津電話機(jī)器人公司 電銷機(jī)器人的風(fēng)險(xiǎn)

一、推理原理

1.標(biāo)定噪聲的特征,使用cv2.inRange二值化標(biāo)識(shí)噪聲對(duì)圖片進(jìn)行二值化處理,具體代碼:cv2.inRange(img, np.array([200, 200, 240]), np.array([255, 255, 255])),把[200, 200, 200]~[255, 255, 255]以外的顏色處理為0

2.使用OpenCV的dilate方法,擴(kuò)展特征的區(qū)域,優(yōu)化圖片處理效果

3.使用inpaint方法,把噪聲的mask作為參數(shù),推理并修復(fù)圖片

二、推理步驟

1.從源圖片,截取右下角部分,另存為新圖片

2.識(shí)別水印,顏色值為:[200, 200, 200]~[255, 255, 255]

3.去掉水印,還原圖片

4.把源圖片、去掉水印的新圖片,進(jìn)行重疊合并

三、參考代碼

import cv2
import numpy as np
from PIL import Image
import os
​
dir = os.getcwd()
path = "1.jpg"
newPath = "new.jpg"
img=cv2.imread(path,1)
hight,width,depth=img.shape[0:3]
​
#截取
cropped = img[int(hight*0.8):hight, int(width*0.7):width]  # 裁剪坐標(biāo)為[y0:y1, x0:x1]
cv2.imwrite(newPath, cropped)
imgSY = cv2.imread(newPath,1)
​
#圖片二值化處理,把[200,200,200]-[250,250,250]以外的顏色變成0
thresh = cv2.inRange(imgSY,np.array([200,200,200]),np.array([250,250,250]))
#創(chuàng)建形狀和尺寸的結(jié)構(gòu)元素
kernel = np.ones((3,3),np.uint8)
#擴(kuò)展待修復(fù)區(qū)域
hi_mask = cv2.dilate(thresh,kernel,iterations=10)
specular = cv2.inpaint(imgSY,hi_mask,5,flags=cv2.INPAINT_TELEA)
cv2.imwrite(newPath, specular)
​
#覆蓋圖片
imgSY = Image.open(newPath)
img = Image.open(path)
img.paste(imgSY, (int(width*0.7),int(hight*0.8),width,hight))
img.save(newPath)

import cv2
import numpy as np
from PIL import Image
import os
​
dir = os.getcwd()
path = "1.jpg"
newPath = "new.jpg"
img=cv2.imread(path,1)
hight,width,depth=img.shape[0:3]
​
#截取
cropped = img[int(hight*0.8):hight, int(width*0.7):width]  # 裁剪坐標(biāo)為[y0:y1, x0:x1]
cv2.imwrite(newPath, cropped)
imgSY = cv2.imread(newPath,1)
​
#圖片二值化處理,把[200,200,200]-[250,250,250]以外的顏色變成0
thresh = cv2.inRange(imgSY,np.array([200,200,200]),np.array([250,250,250]))
#創(chuàng)建形狀和尺寸的結(jié)構(gòu)元素
kernel = np.ones((3,3),np.uint8)
#擴(kuò)展待修復(fù)區(qū)域
hi_mask = cv2.dilate(thresh,kernel,iterations=10)
specular = cv2.inpaint(imgSY,hi_mask,5,flags=cv2.INPAINT_TELEA)
cv2.imwrite(newPath, specular)
​
#覆蓋圖片
imgSY = Image.open(newPath)
img = Image.open(path)
img.paste(imgSY, (int(width*0.7),int(hight*0.8),width,hight))
img.save(newPath)

四、效果圖

沒(méi)去水印前:

去了后:

到此這篇關(guān)于利用Python+OpenCV三步去除水印的文章就介紹到這了,更多相關(guān)Python+OpenCV去水印內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 拒絕盜圖!教你怎么用python給圖片加水印
  • 基于python的圖片修復(fù)程序(實(shí)現(xiàn)水印去除)
  • 運(yùn)用python去除圖片水印
  • Python編程OpenCV和Numpy圖像處理庫(kù)實(shí)現(xiàn)圖片去水印

標(biāo)簽:常州 蘭州 六盤水 成都 江蘇 宿遷 駐馬店 山東

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《利用Python+OpenCV三步去除水印》,本文關(guān)鍵詞  利用,Python+OpenCV,三步,去除,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《利用Python+OpenCV三步去除水印》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于利用Python+OpenCV三步去除水印的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    宁津县| 蒲城县| 泽库县| 五华县| 阿瓦提县| 衡阳县| 新乡市| 新昌县| 申扎县| 攀枝花市| 西丰县| 米脂县| 精河县| 溧阳市| 沛县| 淄博市| 通渭县| 晋宁县| 甘泉县| 德阳市| 珠海市| 清徐县| 且末县| 葵青区| 潮安县| 石景山区| 南雄市| 肃宁县| 彭泽县| 涟水县| 德阳市| 定兴县| 彰武县| 永丰县| 山阴县| 葫芦岛市| 肥西县| 江源县| 慈溪市| 平顶山市| 三穗县|