Dibuja una forma rectangular y extrae objetos usando OpenCV de Python

OpenCV es una biblioteca de software de aprendizaje automático y visión artificial de código abierto. Con su ayuda, se pueden realizar varias operaciones de procesamiento de imágenes, como manipular imágenes y aplicar toneladas de filtros. Se usa ampliamente en la detección de objetos, detección de rostros y otras tareas de procesamiento de imágenes.

Veamos cómo dibujar una forma rectangular en la imagen y extraer los objetos usando OpenCV.

# Python program to extract rectangular
# Shape using OpenCV in Python3
import cv2
import numpy as np
  
drawing = False     # true if mouse is pressed
mode = True         # if True, draw rectangle.
ix, iy = -1, -1
  
# mouse callback function
def draw_circle(event, x, y, flags, param):
    global ix, iy, drawing, mode
      
    if event == cv2.EVENT_LBUTTONDOWN:
        drawing = True
        ix, iy = x, y
      
    elif event == cv2.EVENT_MOUSEMOVE:
        if drawing == True:
            if mode == True:
                cv2.rectangle(img, (ix, iy), (x, y), (0, 255, 0), 3)
                a = x
                b = y
                if a != x | b != y:
                    cv2.rectangle(img, (ix, iy), (x, y), (0, 0, 0), -1)
            else:
                cv2.circle(img, (x, y), 5, (0, 0, 255), -1)
      
    elif event == cv2.EVENT_LBUTTONUP:
        drawing = False
        if mode == True:
            cv2.rectangle(img, (ix, iy), (x, y), (0, 255, 0), 2)
      
        else:
            cv2.circle(img, (x, y), 5, (0, 0, 255), -1)
      
img = np.zeros((512, 512, 3), np.uint8)
cv2.namedWindow('image')
cv2.setMouseCallback('image', draw_circle)
  
while(1):
    cv2.imshow('image', img)
    k = cv2.waitKey(1) & 0xFF
    if k == ord('m'):
        mode = not mode
    elif k == 27:
        break
  
cv2.destroyAllWindows() 

Producción:

El fragmento de código anterior funcionará solo con una imagen de fondo negra. Pero los rectángulos se pueden dibujar en cualquier imagen. Podemos escribir un programa que nos permita seleccionar la parte deseada en una imagen y extraer esa parte seleccionada también. La tarea incluye las siguientes cosas:

  • dibujar forma en cualquier imagen
  • Vuelva a seleccionar la parte del extracto en caso de que haya una mala selección.
  • extraer un objeto particular de la imagen
# Write Python code here
# import the necessary packages
import cv2
import argparse
  
# now let's initialize the list of reference point
ref_point = []
crop = False
  
def shape_selection(event, x, y, flags, param):
    # grab references to the global variables
    global ref_point, crop
  
    # if the left mouse button was clicked, record the starting
    # (x, y) coordinates and indicate that cropping is being performed
    if event == cv2.EVENT_LBUTTONDOWN:
        ref_point = [(x, y)]
  
    # check to see if the left mouse button was released
    elif event == cv2.EVENT_LBUTTONUP:
        # record the ending (x, y) coordinates and indicate that
        # the cropping operation is finished
        ref_point.append((x, y))
  
        # draw a rectangle around the region of interest
        cv2.rectangle(image, ref_point[0], ref_point[1], (0, 255, 0), 2)
        cv2.imshow("image", image)
  
  
# construct the argument parser and parse the arguments
ap = argparse.ArgumentParser()
ap.add_argument("-i", "--image", required = True, help ="Path to the image")
args = vars(ap.parse_args())
  
# load the image, clone it, and setup the mouse callback function
image = cv2.imread(args["image"])
clone = image.copy()
cv2.namedWindow("image")
cv2.setMouseCallback("image", shape_selection)
  
  
# keep looping until the 'q' key is pressed
while True:
    # display the image and wait for a keypress
    cv2.imshow("image", image)
    key = cv2.waitKey(1) & 0xFF
  
    # press 'r' to reset the window
    if key == ord("r"):
        image = clone.copy()
  
    # if the 'c' key is pressed, break from the loop
    elif key == ord("c"):
        break
  
if len(ref_point) == 2:
    crop_img = clone[ref_point[0][1]:ref_point[1][1], ref_point[0][0]:
                                                           ref_point[1][0]]
    cv2.imshow("crop_img", crop_img)
    cv2.waitKey(0)
  
# close all open windows
cv2.destroyAllWindows() 

Ejecutar : guarde el archivo como capture_events.py y, para realizar pruebas, seleccione una imagen de demostración que se encuentra en el mismo directorio. Ahora, ejecute el siguiente comando –

python capture_events.py --image demo.jpg

Salida : primero seleccione la parte deseada de la imagen. Además, podemos eliminar la mala selección presionando ‘r’ según lo programado para hacer una nueva selección adecuada.


Higo: Porción Seleccionada

Ahora, después de seleccionar una selección adecuada como la anterior, simplemente presione ‘c’ para extraer, según lo programado.
Higo: Porción cortada

Publicación traducida automáticamente

Artículo escrito por innat y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *