zuobijiancedaima
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

46 lines
1.6 KiB

from ultralytics import YOLO
import cv2
import os
current_dir = os.path.dirname(os.path.abspath(__file__))
det_model = YOLO(os.path.join(current_dir, "yolov8n-pose.pt"))
cls_model = YOLO(os.path.join(current_dir, "yolov8n-cls.pt"))
# det_model = YOLO('yolov8n-pose.pt')
# cls_model = YOLO('yolov8n-cls.pt')
class_name = ['normal', 'raise_hand', 'speak', 'stand', 'turn_head', 'use_phone']
def infer(image):
det_results = det_model(image, conf=0.5, iou=0.25)
for r in det_results:
if len(r) == 0:
return 'leave'
box = r.boxes.xyxy
if len(box) == 1:
crop_image = image[int(box[0][1]):int(box[0][3]), int(box[0][0]):int(box[0][2])]
cls_results = cls_model(crop_image)
return class_name[cls_results[0].probs.top1]
else:
return 'many_humans'
# image_path = os.path.join(current_dir, "frames/video1_1.png")
# result = infer(image_path)
# print(result)
cap = cv2.VideoCapture(0)
if cap.isOpened():
while True:
ret, frame = cap.read()
if ret:
result = infer(frame)
print(result)
# 设置要添加的文本内容和位置
org = (50, 50) # 文本起始位置
font = cv2.FONT_HERSHEY_SIMPLEX
font_scale = 1
color = (255, 0, 0) # 文本颜色,BGR格式
thickness = 2 # 文本字体粗细
# 添加文本到图像
cv2.putText(frame, result, org, font, font_scale, color, thickness, cv2.LINE_AA)
cv2.imshow('test.png', frame)
cv2.waitKey(1000)