mirror of
https://github.com/leigest519/ScreenCoder.git
synced 2026-02-13 10:12:46 +00:00
Initial commit
This commit is contained in:
89
UIED/result_processing/view_gt.py
Normal file
89
UIED/result_processing/view_gt.py
Normal file
@@ -0,0 +1,89 @@
|
||||
from tqdm import tqdm
|
||||
import json
|
||||
import cv2
|
||||
from os.path import join as pjoin
|
||||
|
||||
from config.CONFIG_UIED import Config
|
||||
C = Config()
|
||||
|
||||
|
||||
def draw_bounding_box_class(org, components, color=C.COLOR, line=2, show=False, write_path=None):
|
||||
"""
|
||||
Draw bounding box of components with their classes on the original image
|
||||
:param org: original image
|
||||
:param components: bbox [(column_min, row_min, column_max, row_max)]
|
||||
-> top_left: (column_min, row_min)
|
||||
-> bottom_right: (column_max, row_max)
|
||||
:param color_map: colors mapping to different components
|
||||
:param line: line thickness
|
||||
:param compo_class: classes matching the corners of components
|
||||
:param show: show or not
|
||||
:return: labeled image
|
||||
"""
|
||||
board = org.copy()
|
||||
bboxes = components['bboxes']
|
||||
categories = components['categories']
|
||||
for i in range(len(bboxes)):
|
||||
bbox = bboxes[i]
|
||||
category = categories[i]
|
||||
board = cv2.rectangle(board, (bbox[0], bbox[1]), (bbox[2], bbox[3]), color[C.CLASS_MAP[str(category)]], line)
|
||||
board = cv2.putText(board, C.CLASS_MAP[str(category)], (bbox[0]+5, bbox[1]+20), cv2.FONT_HERSHEY_SIMPLEX, 0.8, color[C.CLASS_MAP[str(category)]], 2)
|
||||
if show:
|
||||
cv2.imshow('a', cv2.resize(board, (500, 1000)))
|
||||
cv2.waitKey(0)
|
||||
if write_path is not None:
|
||||
cv2.imwrite(write_path, board)
|
||||
return board
|
||||
|
||||
|
||||
def load_ground_truth_json(gt_file, no_text=True):
|
||||
def get_img_by_id(img_id):
|
||||
for image in images:
|
||||
if image['id'] == img_id:
|
||||
return image['file_name'].split('/')[-1][:-4], (image['height'], image['width'])
|
||||
|
||||
def cvt_bbox(bbox):
|
||||
'''
|
||||
:param bbox: [x,y,width,height]
|
||||
:return: [col_min, row_min, col_max, row_max]
|
||||
'''
|
||||
bbox = [int(b) for b in bbox]
|
||||
return [bbox[0], bbox[1], bbox[0] + bbox[2], bbox[1] + bbox[3]]
|
||||
|
||||
data = json.load(open(gt_file, 'r'))
|
||||
images = data['images']
|
||||
annots = data['annotations']
|
||||
compos = {}
|
||||
print('Loading %d ground truth' % len(annots))
|
||||
for annot in tqdm(annots):
|
||||
img_name, size = get_img_by_id(annot['image_id'])
|
||||
if no_text and int(annot['category_id']) == 14:
|
||||
compos[img_name] = {'bboxes': [], 'categories': [], 'size': size}
|
||||
continue
|
||||
if img_name not in compos:
|
||||
compos[img_name] = {'bboxes': [cvt_bbox(annot['bbox'])], 'categories': [annot['category_id']], 'size':size}
|
||||
else:
|
||||
compos[img_name]['bboxes'].append(cvt_bbox(annot['bbox']))
|
||||
compos[img_name]['categories'].append(annot['category_id'])
|
||||
return compos
|
||||
|
||||
|
||||
def view_gt_all(gt, img_root):
|
||||
for img_id in gt:
|
||||
compos = gt[img_id]
|
||||
img = cv2.imread(pjoin(img_root, img_id + '.jpg'))
|
||||
print(pjoin(img_root, img_id + '.jpg'))
|
||||
draw_bounding_box_class(img, compos, show=True)
|
||||
|
||||
|
||||
def view_gt_single(gt, img_root, img_id):
|
||||
img_id = str(img_id)
|
||||
compos = gt[img_id]
|
||||
img = cv2.imread(pjoin(img_root, img_id + '.jpg'))
|
||||
print(pjoin(img_root, img_id + '.jpg'))
|
||||
draw_bounding_box_class(img, compos, show=True)
|
||||
|
||||
|
||||
gt = load_ground_truth_json('E:\\Mulong\\Datasets\\rico\\instances_test.json', no_text=False)
|
||||
# view_gt_all(gt, 'E:\\Mulong\\Datasets\\rico\\combined')
|
||||
view_gt_single(gt, 'E:\\Mulong\\Datasets\\rico\\combined', 670)
|
||||
Reference in New Issue
Block a user