這篇文章給大家介紹利用python編寫一個(gè)圖片修復(fù)功能,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
創(chuàng)新互聯(lián)建站專注于寧都網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供寧都營銷型網(wǎng)站建設(shè),寧都網(wǎng)站制作、寧都網(wǎng)頁設(shè)計(jì)、寧都網(wǎng)站官網(wǎng)定制、微信小程序開發(fā)服務(wù),打造寧都網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供寧都網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。效果預(yù)覽
圖片修復(fù)原理
那OpenCV究竟是怎么實(shí)現(xiàn)的,簡單的來說就是開發(fā)者標(biāo)定噪聲的特征,在使用噪聲周圍的顏色特征推理出應(yīng)該修復(fù)的圖片的顏色,從而實(shí)現(xiàn)圖片修復(fù)的。
程序?qū)崿F(xiàn)解析
#coding=utf-8 #圖片修復(fù) import cv2 import numpy as np path = "img/inpaint.png" img = cv2.imread(path) hight, width, depth = img.shape[0:3] #圖片二值化處理,把[240, 240, 240]~[255, 255, 255]以外的顏色變成0 thresh = cv2.inRange(img, np.array([240, 240, 240]), np.array([255, 255, 255])) #創(chuàng)建形狀和尺寸的結(jié)構(gòu)元素 kernel = np.ones((3, 3), np.uint8) #擴(kuò)張待修復(fù)區(qū)域 hi_mask = cv2.dilate(thresh, kernel, iterations=1) specular = cv2.inpaint(img, hi_mask, 5, flags=cv2.INPAINT_TELEA) cv2.namedWindow("Image", 0) cv2.resizeWindow("Image", int(width / 2), int(hight / 2)) cv2.imshow("Image", img) cv2.namedWindow("newImage", 0) cv2.resizeWindow("newImage", int(width / 2), int(hight / 2)) cv2.imshow("newImage", specular) cv2.waitKey(0) cv2.destroyAllWindows()