This repository has been archived by the owner on Jan 3, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path4_AnnotateImage.py
73 lines (61 loc) · 2.61 KB
/
4_AnnotateImage.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
import argparse
import json
import os
import cv2
from pathlib import Path
import sqlite3
conn = sqlite3.connect(':memory:')
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument("-i", "--input_json", dest="input_json", help="path to a json file in coco format")
parser.add_argument("-p", "--input_image_path", dest="input_image_path", help="path to image folder")
args = parser.parse_args()
json_path = Path(args.input_json)
imgs_path = Path(args.input_image_path)
id_to_file = dict()
id_to_annot = dict()
with open(json_path) as json_file:
data = json.load(json_file)
for img in data['images']:
id_to_file[int(img['id'])] = img['file_name']
for annot in data['annotations']:
key = int(annot['image_id'])
if key not in id_to_annot:
id_to_annot[key] = []
id_to_annot[key].append(annot['keypoints'])
file_to_annot = dict()
for key in id_to_file.keys():
if key in id_to_annot.keys():
file_to_annot[id_to_file[key]] = id_to_annot[key]
del id_to_file
del id_to_annot
cnt = 0
for file in file_to_annot.keys():
path = str(os.path.join(imgs_path, file))
if os.path.exists(path):
img = cv2.imread(path)
for annot in file_to_annot[file]:
keypoints_x = annot[::3]
keypoints_y = annot[1::3]
keypoints_type = annot[2::3]
for i in range(len(keypoints_x)):
if int(keypoints_type[i]) == 2:
cv2.circle(img, (int(keypoints_x[i]), int(keypoints_y[i])), 5, (0, 255, 0), thickness=-1,
lineType=cv2.FILLED)
elif int(keypoints_type[i]) == 1:
cv2.circle(img, (int(keypoints_x[i]), int(keypoints_y[i])), 5, (0, 0, 255), thickness=-1,
lineType=cv2.FILLED)
# cv2.putText(frame, "{}".format(i), (int(x), int(y)),
# cv2.FONT_HERSHEY_SIMPLEX, 1.4,(0, 0, 255), 3, lineType=cv2.LINE_AA)
path2 = str(os.path.join(os.path.join(imgs_path, 'labeled'), file))
# cv2.imshow('test',img)
# cv2.waitKey(0)
# cv2.destroyAllWindows()
folder = os.path.join(imgs_path, 'labeled')
if not os.path.exists(folder):
os.mkdir(folder)
cv2.imwrite(path2, img)
cnt += 1
if cnt % 500 == 0:
print(str(cnt) + " images annotated")
print(str(cnt) + " images annotated")