通过Python调用YOLOv8,检测实时视频,并显示检测结果,需要在视频画面中绘制检测结果
时间: 2024-04-14 09:26:25 浏览: 110
基于Tkinter和OpenCV的目标检测程序源码+权重文件,实现摄像头和视频文件的实时目标检测采用YOLOv8模型进行目标检测
3星 · 编辑精心推荐
您可以使用以下步骤通过Python调用YOLOv8,检测实时视频,并显示检测结果:
1. 首先,安装必要的库。您需要安装OpenCV和YOLOv8的Python API。
```python
pip install opencv-python
pip install opencv-contrib-python
pip install numpy
pip install yolov4
```
2. 导入所需的库。
```python
import cv2
import numpy as np
from yolov4.tf import YOLOv4
```
3. 加载YOLOv8模型。
```python
yolo = YOLOv4()
yolo.classes = "path/to/class_names.txt"
yolo.load_weights("path/to/yolov4.weights")
```
4. 创建视频捕捉对象并设置视频源。
```python
video = cv2.VideoCapture("path/to/video.mp4")
```
5. 循环读取视频帧,对每一帧进行目标检测,并在画面中绘制检测结果。
```python
while True:
ret, frame = video.read()
if not ret:
break
# 对帧进行目标检测
boxes, scores, classes, num_objects = yolo.predict(frame)
# 在画面中绘制检测结果
for i in range(num_objects):
x1, y1, x2, y2 = boxes[i]
label = yolo.classes[classes[i]]
confidence = scores[i]
cv2.rectangle(frame, (x1, y1), (x2, y2), (0, 255, 0), 2)
cv2.putText(frame, f"{label}: {confidence:.2f}", (x1, y1 - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.9, (0, 255, 0), 2)
# 显示帧
cv2.imshow("YOLOv8 Object Detection", frame)
# 按下 'q' 键退出循环
if cv2.waitKey(1) == ord('q'):
break
# 释放资源
video.release()
cv2.destroyAllWindows()
```
以上代码会打开指定的视频文件,逐帧进行目标检测,并在每一帧中绘制检测结果。按下 'q' 键可以退出循环。
请注意,您需要将代码中的路径 "path/to/class_names.txt" 和 "path/to/yolov4.weights" 替换为您自己的文件路径。另外,您还可以根据需要进行调整和优化。
阅读全文