| import glob |
| import json |
| import os |
|
|
| import cv2 |
| import numpy as np |
|
|
|
|
| def get_mask_from_json(json_path, img): |
| try: |
| with open(json_path, "r") as r: |
| anno = json.loads(r.read()) |
| except: |
| with open(json_path, "r", encoding="cp1252") as r: |
| anno = json.loads(r.read()) |
|
|
| inform = anno["shapes"] |
| comments = anno["text"] |
| is_sentence = anno["is_sentence"] |
|
|
| height, width = img.shape[:2] |
|
|
| |
| area_list = [] |
| valid_poly_list = [] |
| for i in inform: |
| label_id = i["label"] |
| points = i["points"] |
| if "flag" == label_id.lower(): |
| continue |
|
|
| tmp_mask = np.zeros((height, width), dtype=np.uint8) |
| cv2.polylines(tmp_mask, np.array([points], dtype=np.int32), True, 1, 1) |
| cv2.fillPoly(tmp_mask, np.array([points], dtype=np.int32), 1) |
| tmp_area = tmp_mask.sum() |
|
|
| area_list.append(tmp_area) |
| valid_poly_list.append(i) |
|
|
| |
| sort_index = np.argsort(area_list)[::-1].astype(np.int32) |
| sort_index = list(sort_index) |
| sort_inform = [] |
| for s_idx in sort_index: |
| sort_inform.append(valid_poly_list[s_idx]) |
|
|
| mask = np.zeros((height, width), dtype=np.uint8) |
| for i in sort_inform: |
| label_id = i["label"] |
| points = i["points"] |
|
|
| if "ignore" in label_id.lower(): |
| label_value = 255 |
| else: |
| label_value = 1 |
|
|
| cv2.polylines(mask, np.array([points], dtype=np.int32), True, label_value, 1) |
| cv2.fillPoly(mask, np.array([points], dtype=np.int32), label_value) |
|
|
| return mask, comments, is_sentence |
|
|
|
|
| if __name__ == "__main__": |
| data_dir = "./train" |
| vis_dir = "./vis" |
|
|
| if not os.path.exists(vis_dir): |
| os.makedirs(vis_dir) |
|
|
| json_path_list = sorted(glob.glob(data_dir + "/*.json")) |
| for json_path in json_path_list: |
| img_path = json_path.replace(".json", ".jpg") |
| img = cv2.imread(img_path)[:, :, ::-1] |
|
|
| |
| mask, comments, is_sentence = get_mask_from_json(json_path, img) |
|
|
| |
| valid_mask = (mask == 1).astype(np.float32)[:, :, None] |
| ignore_mask = (mask == 255).astype(np.float32)[:, :, None] |
| vis_img = img * (1 - valid_mask) * (1 - ignore_mask) + ( |
| (np.array([0, 255, 0]) * 0.6 + img * 0.4) * valid_mask |
| + (np.array([255, 0, 0]) * 0.6 + img * 0.4) * ignore_mask |
| ) |
| vis_img = np.concatenate([img, vis_img], 1) |
| vis_path = os.path.join( |
| vis_dir, json_path.split("/")[-1].replace(".json", ".jpg") |
| ) |
| cv2.imwrite(vis_path, vis_img[:, :, ::-1]) |
| print("Visualization has been saved to: ", vis_path) |
|
|