Comment extraire une zone de polygone en Python

0. Aperçu

Lorsque vous utilisez le format COCO, vous souhaitez souvent extraire uniquement certains objets. À ce moment, il est nécessaire d'utiliser les informations de polygone comme masque pour extraire un objet de l'image. Même si je cherche cette méthode, je ne la trouve pas. Cette fois, je présenterai une telle méthode.

1. Code

Tout d'abord, vous devriez pouvoir le voir en quelques secondes en regardant le code ci-dessous.

import cv2

src_img = cv2.imread("YOUR_PATH")

# parameter
sg = [1, 1, 2, 2, 3, 3]
bb = [1, 1, 2, 2]

# working file
mask = np.zeros_like(src_img) # (y, x, c)

# segmentation data
sg = np.asarray(sg[0])
poly_number = int(len(sg)/2)
poly = np.zeros( (poly_number, 2) )
for i in range(poly_number):
  poly[i][0] = sg[(i * 2) + 0] # x
  poly[i][1] = sg[(i * 2) + 1] # y

# generate mask
mask = cv2.fillConvexPoly(mask, np.array(poly, 'int32'), color=(255, 255, 255))

# generate src_img and mask_image
cv2.imwrite("./src_img.png ", src_img)
cv2.imwrite("./mask.png ", mask)

# masked image
masked_src_img = np.where(mask==255, src_img, mask)
cv2.imwrite("./procData/masked.png ", masked_src_img)

# cropping img
bb = np.asarray(bb, 'int32')
offset_x = bb[0]
offset_y = bb[1]
length_x = bb[2]
length_y = bb[3]
cv2.imwrite("./masked_crop.png ", masked_src_img[offset_y : (offset_y + length_y), offset_x : (offset_x + length_x)])

Tout d'abord, le polygone est converti en une image de masque ci-dessous. Notez que des erreurs autres que ʻint32` se produisent.

cv2.fillConvexPoly(mask, np.array(poly, 'int32'), color=(255, 255, 255))

Ensuite, il vous suffit de spécifier que la partie de l'image de masque avec la valeur 255 utilise la valeur de src_img.

masked_src_img = np.where(mask==255, src_img, mask)

Enfin, si vous recadrez dans la zone de délimitation, vous pouvez extraire une zone spécifique.

Enjoy !

Recommended Posts

Comment extraire une zone de polygone en Python
Comment développer en Python
[Python] Comment faire PCA avec Python
Comment collecter des images en Python
Comment utiliser SQLite en Python
Comment utiliser Mysql avec python
Comment envelopper C en Python
Comment utiliser ChemSpider en Python
Comment utiliser PubChem avec Python
Comment gérer le japonais avec Python
Comment extraire n'importe quel rendez-vous dans Google Agenda avec Python
[Introduction à Python] Comment utiliser la classe en Python?
Comment définir dynamiquement des variables en Python
Comment faire R chartr () en Python
[Itertools.permutations] Comment créer une séquence en Python
Comment utiliser BigQuery en Python
Comment obtenir stacktrace en python
Comment afficher la table quatre-vingt-dix-neuf en python
Comment vérifier la version d'opencv avec python
Comment changer de version de Python dans cloud9
Comment régler le contraste de l'image en Python
Comment utiliser __slots__ dans la classe Python
Comment remplir dynamiquement des zéros avec Python
Comment utiliser les expressions régulières en Python
Comment afficher Hello World en python
Comment utiliser is et == en Python
Comment écrire Ruby to_s en Python
Comment installer Python
Comment utiliser la bibliothèque C en Python
Comment recevoir des arguments de ligne de commande en Python
[REAPER] Comment jouer à Reascript avec Python
Comment effacer un taple dans une liste (Python)
Comment générer une séquence en Python et C ++
Résumé de la façon d'importer des fichiers dans Python 3
Comment simplifier l'ajustement polymorphe restreint en python
Comment utiliser la bibliothèque d'images Python dans la série python3
Comment implémenter la mémoire partagée en Python (mmap.mmap)
Comment créer un fichier JSON en Python
Résumé de l'utilisation de MNIST avec Python
Comment spécifier la version TLS dans les requêtes python
Comment vérifier / extraire des fichiers dans un package RPM
Comment notifier les canaux Discord en Python
Comment obtenir les fichiers dans le dossier [Python]
Comment utiliser tkinter avec python dans pyenv
Comment exécuter LeapMotion avec Python non-Apple
[Python] Comment dessiner un histogramme avec Matplotlib
Comment générer "Ketsumaimo" en standard en Python
Comment gérer le type datetime dans sqlite3 de python
Comment apporter des modifications à l'interpréteur Python dans Pycharm
Comment tracer l'autocorrélation et l'autocorrélation partielle avec Python
Comment supprimer les éléments en double dans la liste Python 3
20e Comment écrire des problèmes en temps réel hors ligne en Python
Comment récupérer la nième plus grande valeur en Python
[Pour les débutants] Comment utiliser la commande say avec python!
Comment convertir / restaurer une chaîne avec [] en python
Comment obtenir le nom de la variable lui-même en python
Comment installer Python [Windows]
Pour vider stdout en Python
Comment obtenir le nombre de chiffres en Python