Инвертировать цвет пикселя между контуром и расширенным контуром - PullRequest
0 голосов
/ 20 сентября 2018

В изображении я нахожу контуры, а затем выбираю один контур за раз, а затем изменяю каждый из них.Мне нужно инвертировать цвета области только между этими двумя контурными линиями.

import cv2
import numpy as np
import matplotlib.pyplot as plt
from skimage import io
%matplotlib inline
im = cv2.imread('bigO.jpg')
im = np.invert(im)
imgray = cv2.cvtColor(im,cv2.COLOR_BGR2GRAY)
# plt.figure(figsize=(10,10))
# plt.imshow(imgray)
ret,thresh = cv2.threshold(imgray, 127,255,cv2.THRESH_BINARY)
image, contours, hierarchy = cv2.findContours(thresh,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)

#Get any one contour
cnt = contours[1]

#Extend the contour
def rand_xy(mu, sigma):
    return np.random.normal(mu, sigma), np.random.normal(mu, sigma)
cnt_new = np.asarray([point + rand_xy(mu = 5., sigma = 0.5) for point in cnt], dtype=np.int32)

#DRAW CONTOURS
cv2.drawContours(im, cnt, -1, (255, 0, 0), 1)
cv2.drawContours(im, cnt_new, -1, (255, 0, 0), 1)
plt.figure(figsize=(10,10))
plt.imshow(im)

#Here I need to invert the color of images between the contours.

enter image description here

enter image description here

Ожидаемый результат:

Ожидаемыйвсе изображение с пикселями, инвертированными между двумя контурами.

1 Ответ

0 голосов
/ 20 сентября 2018

Бинаризируйте изображение и инвертируйте его, применяя побитовый оператор not

im = np.clip(im,0,255).astype(np.uint8)
im = cv2.bitwise_not(im)

или:

_, im = cv2.threshold(im.astype(np.uint8),0,255,cv2.THRESH_OTSU|cv2.THRESH_BINARY_INV)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...