opencv-python读取图片和lableme标注的json文件并显示mask

只是需要使用lableme标准的json文件获取mask,经过分析使用其他库的必要性比较低,于是自己写了一个通过labelme标准的json文件获取mask的程序。这里我使用的json文件只是标注了个polygon。

import cv2
import numpy as np
import json

json_path = r'D:\datasets\24\2022-01-05\10_color_1.json'
img_path = r'D:\datasets\24\2022-01-05\10_color_1.png'

labelme_json = json.load(open(json_path, encoding='utf-8'))
img = cv2.imread(img_path)

mask = np.zeros((720, 1280, 1), dtype=np.uint8)
mask2 = np.zeros((720, 1280, 3), dtype=np.uint8)
points = labelme_json['shapes'][0]['points']
points = np.array(points)
points = points.reshape(-1, 1, 2)
points = points.astype(np.int32)

cv2.fillConvexPoly(mask, points, (255,))
cv2.fillConvexPoly(mask2, points, (255,255,255))

# 显示mask
cv2.imshow('mask', mask)
cv2.waitKey(0)

# new_image = cv2.bitwise_and(img, mask)
new_image = cv2.bitwise_and(img, mask2)
# new_image[mask2==255] = 100
# 显示mask区域图像
cv2.imshow('new_image', new_image)
cv2.waitKey(0)

运行结果:

 

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值