-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathtest_image.py
51 lines (42 loc) · 2.08 KB
/
test_image.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
import time
import sys
import pathlib
import logging
import cv2
from tools.test_detect import MtcnnDetector
logger = logging.getLogger("app")
formatter = logging.Formatter('%(asctime)s %(levelname)-8s: %(message)s')
console_handler = logging.StreamHandler(sys.stdout)
logger.addHandler(console_handler)
logger.setLevel(logging.INFO)
console_handler.formatter = formatter # 也可以直接给formatter赋值
def draw_images(img, bboxs, landmarks): # 在图片上绘制人脸框及特征点
num_face = bboxs.shape[0]
for i in range(num_face):
cv2.rectangle(img, (int(bboxs[i, 0]), int(bboxs[i, 1])), (int(
bboxs[i, 2]), int(bboxs[i, 3])), (0, 255, 0), 3)
for p in landmarks:
for i in range(5):
cv2.circle(img, (int(p[2 * i]), int(p[2 * i + 1])), 6, (0, 0, 255), -1)
return img
if __name__ == '__main__':
mtcnn_detector = MtcnnDetector(min_face_size=24, use_cuda=False) # 加载模型参数,构造检测器
logger.info("Init the MtcnnDetector.")
project_root = pathlib.Path()
inputPath = project_root / "data" / "test_images"
outputPath = project_root / "data" / "you_result"
outputPath.mkdir(exist_ok=True)
start = time.time()
for num, input_img_filename in enumerate(inputPath.iterdir()):
logger.info("Start to process No.{} image.".format(num))
img_name = input_img_filename.name
logger.info("The name of the image is {}.".format(img_name))
img = cv2.imread(str(input_img_filename))
RGB_image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
bboxs, landmarks = mtcnn_detector.detect_face(RGB_image) # 检测得到bboxs以及特征点
img = draw_images(img, bboxs, landmarks) # 得到绘制人脸框及特征点的图片
savePath = outputPath / img_name # 图片保存路径
logger.info("Process complete. Save image to {}.".format(str(savePath)))
cv2.imwrite(str(savePath), img) # 保存图片
logger.info("Finish all the images.")
logger.info("Elapsed time: {:.3f}s".format(time.time() - start))