Простой метод - извлечь ROI, используя Numpy нарезку, пикселизировать, а затем вставить его обратно в исходное изображение. Я буду использовать технику пикселизации, найденную в , как пикселизировать изображение с помощью OpenCV в Python? . Вот простой пример:
Входное изображение и ROI для извлечения
Извлеченный ROI
ROI с точками
Результат
Код
import cv2
def pixelate(image):
# Get input size
height, width, _ = image.shape
# Desired "pixelated" size
h, w = (16, 16)
# Resize image to "pixelated" size
temp = cv2.resize(image, (w, h), interpolation=cv2.INTER_LINEAR)
# Initialize output image
return cv2.resize(temp, (width, height), interpolation=cv2.INTER_NEAREST)
# Load image
image = cv2.imread('1.png')
# ROI bounding box coordinates
x,y,w,h = 122,98,283,240
# Extract ROI
ROI = image[y:y+h, x:x+w]
# Pixelate ROI
pixelated_ROI = pixelate(ROI)
# Paste pixelated ROI back into original image
image[y:y+h, x:x+w] = pixelated_ROI
cv2.imshow('pixelated_ROI', pixelated_ROI)
cv2.imshow('image', image)
cv2.waitKey()
Примечание: Координаты ограничительной рамки ROI были найдены с помощью скрипта в , как получить координаты ограничительной рамки ROI без Guess & Check . В вашем случае я предполагаю, что у вас уже есть координаты x,y,w,h
ограничительной рамки, полученные с помощью cv2.boundingRect
.