婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > OpenCV圖像修復cv2.inpaint()的使用

OpenCV圖像修復cv2.inpaint()的使用

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

這篇博客將介紹如何通過OpenCV中圖像修復的技術——cv2.inpaint() 去除舊照片中的小噪音、筆劃等。并提供一個可交互式的程序,利用OpenCV的快速行進和流體力學倆種修復算法對自己的圖片進行修復。

大多數人家里都會有一些舊的老化照片,上面有一些黑點、筆劃等。如何復原呢?


在繪制工具中擦除:將簡單地用無用的白色結構替換黑色結構,效果并不理想。OpenCV中圖像修復的技術——基本思想很簡單:用相鄰像素替換這些壞標記,使其看起來像鄰居。

  • cv2.INPAINT_TELEA(Fast Marching Method 快速行進算法)
  • cv2.INPAINT_NS(Fluid Dynamics Method 流體力學算法)
  • OpenCV未實現的:Content-Aware Fill 內容感知填充算法,這是Adobe Photoshop中使用的一種高級修復技術。

cv2.inpaint() 優點:修復效果更加自然;
缺點:修復時需要提供原圖以及mask圖(與原圖一致只有被污染的像素區域有值);

1. 效果圖

官方原始圖 VS mask圖 VS 快速行進算法修復效果 VS 流體力學修復效果 如下:


接下來用可交互的例子實現自己的圖片修復;

原始圖 VS Mask圖 VS 快速行進算法修復效果圖如下:
原始圖隨意用鼠標左鍵移動繪制點、線,右鍵移動繪制矩形來隨機增加一些被污染的區域;
并根據原始圖生成mask圖,mask圖是與原始圖具有相同大小,并且只有被污染的區域是白色像素的圖。可以看到修復效果還是挺好的~

原始圖 VS Mask圖 VS 流體力學算法修復效果圖如下:
原始圖隨意用鼠標左鍵移動繪制點、線,右鍵移動繪制矩形來隨機增加一些被污染的區域;
mask圖是與原始圖具有相同大小,并且只有被污染的區域是白色像素的圖。可以看到修復效果還是挺好的~

快速行進算法與流體力學算法修復的效果圖差別不太大;

2. 原理

  • cv2.INPAINT_TELEA (Fast Marching Method 快速行進算法),對位于點附近、邊界法線附近和邊界輪廓上的像素賦予更多權重。一旦一個像素被修復,它將使用快速行進的方法移動到下一個最近的像素。
  • cv2.INPAINT_NS(Fluid Dynamics Method 流體力學算法),使用了流體力學的一些方法,基本原則是啟發式的。首先沿著邊從已知區域移動到未知區域(因為邊是連續的)。它在匹配修復區域邊界處的漸變向量的同時,繼續等高線(連接具有相同強度的點的線,就像等高線連接具有相同高程的點一樣)。
  • OpenCV未實現的:Content-Aware Fill 內容感知填充算法,這是Adobe Photoshop中使用的一種高級修復技術。

3. 源碼

# 圖像修復交互式案例——通過水流填充算法來修復被破壞的圖像區域;
# 使用倆種方法進行修復
# cv2.INPAINT_TELEA (Fast Marching Method 快速行進算法),對位于點附近、邊界法線附近和邊界輪廓上的像素賦予更多權重。一旦一個像素被修復,它將使用快速行進的方法移動到下一個最近的像素。
# cv2.INPAINT_NS 流體力學算法,使用了流體力學的一些方法,基本原則是啟發式的,首先沿著邊從已知區域移動到未知區域(因為邊是連續的)。它在匹配修復區域邊界處的漸變向量的同時,繼續等高線(連接具有相同強度的點的線,就像等高線連接具有相同高程的點一樣)。

# USAGE 
# python inpaint.py D:/deepLearning/py-demo/20210808/images/ml.jpg

# 按下鼠標左鍵,添加點、線,按下鼠標右鍵,添加矩形框,以制作被污染的需要修復圖像
# 按下空格鍵:執行修復功能
# 按下r鍵:重置待修復的mask
# 按下esc鍵,退出
import cv2
import numpy as np


class Sketcher:
    def __init__(self, windowname, dests, colors_func):
        self.prev_pt = None  # 線起始點
        self.drag_start = None  # 矩形起點
        self.drag_rect = None  # 矩形(左上角,右下角)坐標
        self.windowname = windowname
        self.dests = dests
        self.colors_func = colors_func
        self.dirty = False
        self.drawing = False
        self.mode = False
        self.show()
        cv2.setMouseCallback(self.windowname, self.on_mouse)

    def show(self):
        cv2.imshow(self.windowname, self.dests[0])

    def on_mouse(self, event, x, y, flags, param):
        pt = (x, y)
        if event == cv2.EVENT_LBUTTONDOWN:
            self.prev_pt = pt
            self.drawing = True
        elif event == cv2.EVENT_RBUTTONDOWN:
            # 第一次初始化時設定pt,往后保留上一個點作為矩形起點
            if self.drag_start == None:
                self.drag_start = pt

        if self.prev_pt and flags  cv2.EVENT_FLAG_LBUTTON:
            for dst, color in zip(self.dests, self.colors_func()):
                cv2.line(dst, self.prev_pt, pt, color, 5)
            self.dirty = True
            self.prev_pt = pt
            self.show()

        if self.drag_start and flags  cv2.EVENT_FLAG_RBUTTON:
            xo, yo = self.drag_start
            x0, y0 = np.minimum([xo, yo], [x, y])
            x1, y1 = np.maximum([xo, yo], [x, y])
            self.drag_rect = None
            if x1 - x0 > 0 and y1 - y0 > 0:
                self.drag_rect = (x0, y0, x1, y1)
                for dst, color in zip(self.dests, self.colors_func()):
                    cv2.rectangle(dst, (x0, y0), (x1, y1), color, -1)
                self.dirty = True
                self.drag_start = None
                self.drag_rect = None
                self.show()
            else:
                self.drag_start = pt

    @property
    def dragging(self):
        return self.drag_rect is not None


def main():
    import sys
    try:
        fn = sys.argv[1]
    except:
        fn = 'images/ml_.jpg'

    img = cv2.imread(fn)
    if img is None:
        print('Failed to load image file:', fn)
        sys.exit(1)

    img_mark = img.copy()
    mark = np.zeros(img.shape[:2], np.uint8)
    sketch = Sketcher('img', [img_mark, mark], lambda: ((255, 255, 255), 255))

    while True:
        ch = cv2.waitKey()
        if ch == 27:
            break
        if ch == ord(' '):
            cv2.imshow('mask', mark)
            fmmres = cv2.inpaint(img_mark, mark, 3, cv2.INPAINT_TELEA)
            nsres = cv2.inpaint(img_mark, mark, 3, cv2.INPAINT_NS)
            cv2.imshow('inpaint fmm res', fmmres)
            cv2.imshow('inpaint ns res', nsres)
        if ch == ord('r'):
            img_mark[:] = img
            mark[:] = 0
            sketch.show()

    print('Done')


if __name__ == '__main__':
    main()
    cv2.destroyAllWindows()

參考 https://docs.opencv.org/3.0-beta/doc/py_tutorials/py_photo/py_inpainting/py_inpainting.html#inpainting

到此這篇關于OpenCV圖像修復cv2.inpaint()的使用的文章就介紹到這了,更多相關OpenCV圖像修復cv2.inpaint()內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python 用opencv實現圖像修復和圖像金字塔
  • OpenCV中圖像通道操作的深入講解
  • Python深度學習pytorch實現圖像分類數據集
  • Python實現對照片中的人臉進行顏值預測
  • Python實現老照片修復之上色小技巧

標簽:許昌 贛州 濰坊 七臺河 渭南 西安 辛集 雅安

巨人網絡通訊聲明:本文標題《OpenCV圖像修復cv2.inpaint()的使用》,本文關鍵詞  OpenCV,圖像,修復,cv2.inpaint,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《OpenCV圖像修復cv2.inpaint()的使用》相關的同類信息!
  • 本頁收集關于OpenCV圖像修復cv2.inpaint()的使用的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品国产成人系列| 免费不卡在线视频| 色婷婷激情综合| 一区二区三区精品在线| 久久久久九九视频| 欧美日韩久久久久久| 欧美精品一区二区三区蜜臀| 精品卡一卡二卡三卡四在线| 精品国产乱码久久久久久图片 | 亚洲国产精品久久久久秋霞影院 | 在线观看av一区| 91蝌蚪porny九色| 国产成人av影院| 奇米精品一区二区三区四区| 亚洲免费在线电影| 国产精品理论片在线观看| 日韩一区二区三区在线| 精品视频1区2区3区| 色丁香久综合在线久综合在线观看| 韩国视频一区二区| 青青青爽久久午夜综合久久午夜| 亚州成人在线电影| 欧美日韩一区二区在线观看视频| 中文字幕日本不卡| 亚洲欧美一区二区久久| 亚洲午夜国产一区99re久久| 美女视频一区在线观看| 白白色亚洲国产精品| 美女尤物国产一区| 午夜不卡av免费| 午夜精品久久久久影视| 国产成人午夜视频| 亚洲在线中文字幕| 亚洲精品欧美专区| 亚洲精品成人天堂一二三| 国产欧美一区二区三区在线看蜜臀| 日韩一区二区三区视频在线| 精品毛片乱码1区2区3区| 欧美zozozo| 奇米色一区二区三区四区| 石原莉奈一区二区三区在线观看| 亚洲午夜国产一区99re久久| 午夜精品久久久久久久久久| 久久精品国产亚洲高清剧情介绍| 蜜臀av一级做a爰片久久| 日韩av在线发布| 蜜桃精品在线观看| 久久99国产精品麻豆| 国产69精品久久久久777| av毛片久久久久**hd| 欧洲精品一区二区三区在线观看| 91精品国产一区二区三区| 久久精品亚洲麻豆av一区二区| 亚洲精品大片www| 亚洲va韩国va欧美va精品| 一区二区三区免费网站| 日韩va欧美va亚洲va久久| 经典三级一区二区| 97se亚洲国产综合自在线观| 欧美日韩成人综合天天影院 | 日韩欧美色综合网站| 久久嫩草精品久久久精品一| 亚洲精选免费视频| 精品一区二区三区视频在线观看| 一本色道a无线码一区v| 久久影院电视剧免费观看| 亚洲综合精品自拍| 成人国产视频在线观看| 欧美精品高清视频| 亚洲精品久久久久久国产精华液| 国产乱码一区二区三区| 欧美亚洲国产bt| 国产精品久久久久一区二区三区共| 美日韩一区二区三区| 色综合久久中文综合久久牛| 国产农村妇女毛片精品久久麻豆 | 欧美日韩激情一区二区| 亚洲国产精品二十页| 日本不卡123| 亚洲一区二区三区四区在线| 国产伦精品一区二区三区免费迷| 欧美96一区二区免费视频| 黑人精品欧美一区二区蜜桃| 日本精品视频一区二区| 日本一区二区三区国色天香| 蜜桃av一区二区三区| 欧美日韩不卡视频| 亚洲精品成a人| 成人激情小说乱人伦| 久久九九全国免费| 日韩高清不卡一区二区三区| 欧美日韩一级片在线观看| 亚洲视频精选在线| av在线一区二区三区| 国产精品电影一区二区| 成人av影视在线观看| 国产日韩高清在线| 精品系列免费在线观看| 欧美成人免费网站| 美女mm1313爽爽久久久蜜臀| 日韩三级高清在线| 老司机精品视频导航| 精品成a人在线观看| 国产激情视频一区二区三区欧美| 国产欧美精品一区二区色综合 | 在线日韩一区二区| 亚洲欧美日韩国产手机在线| 色94色欧美sute亚洲13| 亚洲综合视频在线| 欧美人伦禁忌dvd放荡欲情| 日本在线观看不卡视频| 午夜激情一区二区三区| 在线精品视频免费播放| 亚洲1区2区3区4区| 精品sm捆绑视频| 国产精品91xxx| 亚洲美女屁股眼交3| 91精品国产免费| 国产一区二区三区免费播放| 国产精品人妖ts系列视频| 欧美亚洲国产bt| 精品制服美女丁香| 亚洲国产成人一区二区三区| 91久久人澡人人添人人爽欧美 | 日本伊人精品一区二区三区观看方式| 欧美剧情电影在线观看完整版免费励志电影| 婷婷成人激情在线网| 久久免费美女视频| 91麻豆免费视频| 精品一二三四区| 亚洲国产精品高清| 欧洲国内综合视频| 视频一区在线播放| 国产亚洲综合av| 在线观看免费亚洲| 男女性色大片免费观看一区二区 | 97精品久久久久中文字幕| 亚洲美女视频一区| 91超碰这里只有精品国产| 国产麻豆视频一区| 亚洲在线一区二区三区| 精品国产一区久久| 精品视频123区在线观看| 国产一区二区福利| 亚洲成人免费影院| 国产精品国产三级国产普通话99| 日韩午夜激情视频| 国产一区二区三区免费在线观看| |精品福利一区二区三区| 91精品一区二区三区久久久久久| 99精品一区二区| 黑人精品欧美一区二区蜜桃 | 欧美日韩国产另类一区| 国产成人啪免费观看软件| 亚洲另类春色国产| 精品99一区二区三区| 3d动漫精品啪啪1区2区免费 | 成人免费视频一区| 久久99久久99小草精品免视看| 国产精品女上位| 日韩欧美一区在线| 在线视频亚洲一区| 成人做爰69片免费看网站| 日韩和欧美一区二区三区| 亚洲黄色在线视频| 亚洲少妇中出一区| 中文字幕在线一区| 久久毛片高清国产| 欧美一区二区三区四区五区| 91精品久久久久久久久99蜜臂| 欧美亚洲愉拍一区二区| caoporm超碰国产精品| 国产美女在线精品| 日日夜夜一区二区| 亚洲精品第一国产综合野| 精品国产免费人成在线观看| 欧美日韩精品综合在线| 欧美在线观看一区二区| 色天使色偷偷av一区二区| 91影院在线观看| 国产69精品久久久久毛片| 成人免费毛片高清视频| 成人午夜视频在线观看| 99精品视频在线观看| 色先锋资源久久综合| 成人免费看视频| 国产成人免费视频网站| 不卡一区中文字幕| 91精品办公室少妇高潮对白| 欧美日韩黄色影视| 欧美日韩国产另类一区| 欧美一区二区大片| 精品国产污污免费网站入口| 国产欧美一区二区精品久导航| 日本一区二区三区在线不卡| 日本一区二区三区高清不卡| 日韩毛片高清在线播放| 亚洲一级电影视频| 裸体在线国模精品偷拍| 国产盗摄一区二区|