-
Notifications
You must be signed in to change notification settings - Fork 0
/
draw.py
54 lines (41 loc) · 1.3 KB
/
draw.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
from PIL import Image, ImageDraw
from PIL.Image import Image as PILImage
from scrfd import SCRFD, Face, Point
def main() -> None:
model_path = "./models/scrfd.onnx"
face_detector = SCRFD.from_path(model_path)
image_path = "./images/solvay_conference_1927.jpg"
image = Image.open(image_path).convert("RGB")
faces = face_detector.detect(image)
result = draw_faces(image, faces)
result.save("draw_result.png")
def draw_faces(
image: PILImage,
faces: list[Face],
radius: int = 3,
box_width: int = 4,
) -> PILImage:
image = image.copy()
draw = ImageDraw.Draw(image)
def to_tuple(p: Point) -> tuple[int, int]:
return int(p.x), int(p.y)
for face in faces:
bbox = face.bbox
p1 = to_tuple(bbox.upper_left)
p2 = to_tuple(bbox.lower_right)
draw.rectangle((p1, p2), outline="red", width=box_width)
kps = face.keypoints
keypoints = [
kps.left_eye,
kps.right_eye,
kps.nose,
kps.left_mouth,
kps.right_mouth,
]
for kp in keypoints:
x, y = to_tuple(kp)
ellipse = [(x - radius, y - radius), (x + radius, y + radius)]
draw.ellipse(ellipse, fill="red")
return image
if __name__ == "__main__":
main()