inpaint.py sample added
This commit is contained in:
parent
f0a4185b1f
commit
afad87b5f2
35
samples/python2/inpaint.py
Normal file
35
samples/python2/inpaint.py
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
import numpy as np
|
||||||
|
import cv2
|
||||||
|
from common import Sketcher
|
||||||
|
|
||||||
|
help_message = '''USAGE: inpaint.py [<image>]
|
||||||
|
|
||||||
|
Keys:
|
||||||
|
SPACE - update inpaint
|
||||||
|
r - restore image
|
||||||
|
ESC - exit
|
||||||
|
'''
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import sys
|
||||||
|
try: fn = sys.argv[1]
|
||||||
|
except: fn = '../cpp/fruits.jpg'
|
||||||
|
print help_message
|
||||||
|
|
||||||
|
img = cv2.imread(fn)
|
||||||
|
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(' '):
|
||||||
|
res = cv2.inpaint(img_mark, mark, 3, cv2.INPAINT_TELEA)
|
||||||
|
cv2.imshow('inpaint', res)
|
||||||
|
if ch == ord('r'):
|
||||||
|
img_mark[:] = img
|
||||||
|
mark[:] = 0
|
||||||
|
sketch.show()
|
||||||
|
|
@ -36,7 +36,7 @@ class App:
|
|||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
while True:
|
while True:
|
||||||
ch = cv2.waitKey(10)
|
ch = cv2.waitKey(50)
|
||||||
if ch == 27:
|
if ch == 27:
|
||||||
break
|
break
|
||||||
if ch >= ord('1') and ch <= ord('7'):
|
if ch >= ord('1') and ch <= ord('7'):
|
||||||
@ -52,7 +52,6 @@ class App:
|
|||||||
self.markers[:] = 0
|
self.markers[:] = 0
|
||||||
self.markers_vis[:] = self.img
|
self.markers_vis[:] = self.img
|
||||||
self.sketch.show()
|
self.sketch.show()
|
||||||
cv2.destroyWindow('watershed')
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
Loading…
x
Reference in New Issue
Block a user