You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
2.4 KiB
75 lines
2.4 KiB
from matplotlib.widgets import RectangleSelector
|
|
import matplotlib.pyplot as plt
|
|
from function import *
|
|
import numpy as np
|
|
|
|
# verrifier que l'image est de même taille que le mask
|
|
|
|
def onSelect(eclick, erelease):
|
|
# remplace les pixels sélectioné en rouge et enregistre ses pixels comme étant à modifé
|
|
x1, y1 = int(eclick.xdata), int(eclick.ydata)
|
|
x2, y2 = int(erelease.xdata), int(erelease.ydata)
|
|
img[y1:y2+1,x1:x2+1] = (255,0,0)
|
|
mask[y1:y2+1,x1:x2+1] = True
|
|
maskImg[y1:y2+1,x1:x2+1] = 255
|
|
ax.imshow(img)
|
|
plt.draw()
|
|
|
|
imgOr = read(input("lien relatif de l'image: "))
|
|
img = imgOr.copy()
|
|
|
|
rep = input("avez vous le mask de l'image (y:n): ")
|
|
yes = ["y","Y","yes","YES","Yes","o","O","oui","OUI"]
|
|
height, width = img.shape[:2]
|
|
if (rep in yes):
|
|
# récupère le mask enregistré
|
|
maskImg = read(input("lien relatife de l'image: "))
|
|
if (len(maskImg.shape) == 3):
|
|
maskImg = maskImg[:,:,0]
|
|
mask = maskImg == 255
|
|
img[mask] = (255,0,0)
|
|
else:
|
|
# lance la fenêtre de selection
|
|
fig, ax = plt.subplots()
|
|
plt.axis("off")
|
|
ax.imshow(img)
|
|
mask = np.zeros((height, width), dtype=bool)
|
|
maskImg = np.zeros((height, width), dtype=np.uint8)
|
|
# permet la selection en rectangle sur l'image et appelle la fonction onSelect
|
|
toggle_selector = RectangleSelector(ax, onSelect, useblit=True,
|
|
button=[1], minspanx=5, minspany=5, spancoords='pixels',
|
|
interactive=True)
|
|
plt.imshow(img)
|
|
plt.show()
|
|
|
|
# lance une nouvelle fenêtre que l'on vas pouvoir annimer en fonction de l'avancement de l'inpainting
|
|
plt.ion()
|
|
plt.axis("off")
|
|
|
|
plt.imshow(mask)
|
|
plt.show()
|
|
plt.title("mask de l'image")
|
|
plt.pause(1)
|
|
plt.title("génération de l'image")
|
|
# lance l'impainting sur img avec le mask mask avec une taile de patch de 2
|
|
res = doTheInpainting(img,mask,2)
|
|
plt.ioff()
|
|
|
|
if input("afficher le résultat avant après (y/n): ") in yes:
|
|
fig, (ax1, ax2) = plt.subplots(1, 2)
|
|
ax1.imshow(imgOr)
|
|
ax1.set_title('Original')
|
|
ax1.axis("off")
|
|
ax2.imshow(res)
|
|
ax2.set_title('Result')
|
|
ax2.axis("off")
|
|
plt.show()
|
|
|
|
if input("enregister le mask (y/n):") in yes:
|
|
save_path = input("Entrez le chemin d'enregistrement du mask: ")
|
|
plt.imsave(save_path, maskImg, cmap='gray')
|
|
|
|
if input("enregister l'image produite (y/n):") in yes:
|
|
save_path = input("Entrez le chemin d'enregistrement de l'image: ")
|
|
plt.imsave(save_path, res)
|