当前位置:   article > 正文

python显示rtsp视频,并实时框人员 推送给流媒体服务器_cv2.videowriter rtmp

cv2.videowriter rtmp

要在Python中显示RTSP视频流、实时框出画面中的人员,并将带有框的视频推送至流媒体服务器,可以分为以下几个步骤:

步骤一:获取RTSP视频流并进行人员检测

这部分与之前回答中展示的代码类似,使用OpenCV读取RTSP视频流并进行人员检测(这里仍以人脸检测为例,您可以替换为其他人员检测模型)。同时,为了将检测结果叠加到原视频流上,我们需要保留原视频帧和检测到的人员框信息:

 

python

  1. import cv2
  2. rtsp_url = 'rtsp://your_rtsp_stream_url'
  3. cap = cv2.VideoCapture(rtsp_url)
  4. if not cap.isOpened():
  5. print("Could not open RTSP stream.")
  6. exit(-1)
  7. face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
  8. while True:
  9. ret, frame = cap.read()
  10. if not ret:
  11. print("Failed to read frame.")
  12. break
  13. gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
  14. faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30))
  15. # 存储检测到的人员框信息
  16. person_boxes = [(x, y, x+w, y+h) for (x, y, w, h) in faces]
  17. # 在原帧上绘制矩形框
  18. for box in person_boxes:
  19. cv2.rectangle(frame, (box[0], box[1]), (box[2], box[3]), (0, 255, 0), 2)
  20. # 显示带有框的帧(可选,仅用于本地调试)
  21. cv2.imshow('RTSP Video Stream with Person Detection', frame)
  22. if cv2.waitKey(1) & 0xFF == ord('q'):
  23. break

步骤二:推送带有框的视频至流媒体服务器

这里以使用opencv-python内置的cv2.VideoWriter类将处理后的视频帧写入RTMP流为例。请确保您使用的OpenCV版本支持RTMP输出,并且流媒体服务器(如Nginx-RTMP、Wowza、OBS等)已配置好接收RTMP流的地址。

 

python

  1. import cv2
  2. rtsp_url = 'rtsp://your_rtsp_stream_url'
  3. rtmp_output_url = 'rtmp://your_rtmp_server_address/stream_key'
  4. cap = cv2.VideoCapture(rtsp_url)
  5. if not cap.isOpened():
  6. print("Could not open RTSP stream.")
  7. exit(-1)
  8. face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml')
  9. # 初始化VideoWriter,指定编码、帧率、分辨率和输出URL
  10. fourcc = cv2.VideoWriter_fourcc(*'FLV1') # 或根据实际情况选择其他编码器
  11. fps = cap.get(cv2.CAP_PROP_FPS)
  12. frame_width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
  13. frame_height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
  14. out = cv2.VideoWriter(rtmp_output_url, fourcc, fps, (frame_width, frame_height))
  15. while True:
  16. ret, frame = cap.read()
  17. if not ret:
  18. print("Failed to read frame.")
  19. break
  20. gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
  21. faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30))
  22. person_boxes = [(x, y, x+w, y+h) for (x, y, w, h) in faces]
  23. for box in person_boxes:
  24. cv2.rectangle(frame, (box[0], box[1]), (box[2], box[3]), (0, 255, 0), 2)
  25. # 将处理后的帧写入RTMP流
  26. out.write(frame)
  27. # 显示带有框的帧(可选,仅用于本地调试)
  28. cv2.imshow('RTSP Video Stream with Person Detection', frame)
  29. if cv2.waitKey(1) & 0xFF == ord('q'):
  30. break
  31. # 释放资源
  32. cap.release()
  33. out.release()
  34. cv2.destroyAllWindows()

在这个示例中:

  1. 使用cv2.VideoWriter创建一个RTMP输出对象,指定编码器、帧率、分辨率和RTMP输出URL。
  2. 在主循环中,读取视频帧,进行人员检测,绘制矩形框,然后将处理后的帧写入out对象(即RTMP流)。
  3. 本地调试时可选择显示带有框的帧,按'q'键退出。

请注意,实际使用时需要根据您的流媒体服务器设置调整rtmp_output_url。如果您的OpenCV版本不支持RTMP输出,或者需要更灵活的流推送方式,可以考虑使用第三方库如ffmpeg-pythonstreamlink结合ffmpeg命令行工具进行流推送。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/喵喵爱编程/article/detail/775926
推荐阅读
相关标签
  

闽ICP备14008679号