实例介绍
【实例简介】基于python VLC实现rtsp网络视频流的接收和存储
【实例截图】
【核心代码】# coding=gbk
import os, time
# 设置VLC库路径,需在import vlc之前
os.environ['PYTHON_VLC_MODULE_PATH'] = "./vlc-3.0.16"
import vlc
import ctypes
import time
import sys
import cv2
import numpy
import datetime
#import PIL
from PIL import Image
vlcInstance = vlc.Instance()
# 记得换url,最好也和上面一样进行测试一下
url = "cc 00_00_02-00_01_03.mp4"
m = vlcInstance.media_new(url)
mp = vlc.libvlc_media_player_new_from_media(m)
# ***如果显示不完整,调整以下宽度和高度的值来适应不同分辨率的图像***
video_width = 1920
video_height = 1080
size = video_width * video_height * 4
buf = (ctypes.c_ubyte * size)()
buf_p = ctypes.cast(buf, ctypes.c_void_p)
VideoLockCb = ctypes.CFUNCTYPE(ctypes.c_void_p, ctypes.c_void_p, ctypes.POINTER(ctypes.c_void_p))
@VideoLockCb
def _lockcb(opaque, planes):
# print("lock", file=sys.stderr)
planes[0] = buf_p
#videosave
fps = 15
size = (video_width, video_height)
#定义编码格式mpge-4
fourcc = cv2.VideoWriter_fourcc('M', 'P', '4', '2')
#定义视频文件输入对象
now_begin = int(time.time())
@vlc.CallbackDecorators.VideoDisplayCb
def _display(opaque, picture):
now_fps_begin = int(round(1000*time.time()))
img = Image.frombuffer("RGBA", (video_width, video_height), buf, "raw", "BGRA", 0, 1)
opencv_image = cv2.cvtColor(numpy.array(img), cv2.COLOR_RGB2BGR)
cv2.imshow('image', opencv_image)
now_fps_end = int(round(1000*time.time()))
fps_now = 60-now_fps_end now_fps_begin
if fps_now>0:
outVideo.write(opencv_image)
cv2.waitKey(fps_now)
#print(fps_now)
vlc.libvlc_video_set_callbacks(mp, _lockcb, None, _display, None)
mp.video_set_format("BGRA", video_width, video_height, video_width * 4)
now_begin1 = int(time.time())
time_Distance = 0
#转换为其他日期格式,如:"%Y-%m-%d %H:%M:%S"
timeArray = time.localtime(now_begin1)
otherStyleTime = time.strftime("%Y_%m_%d_%H_%M_%S", timeArray)
AVI = '.avi'
AVI_Name = otherStyleTime ".avi"
print(AVI_Name )
outVideo = cv2.VideoWriter(AVI_Name,fourcc,fps,size)
while time_Distance<=60:
mp.play()
now_end = int(time.time())
time_Distance = now_end - now_begin1
#print(time_Distance)
time.sleep(1)
【实例截图】

【核心代码】# coding=gbk
import os, time
# 设置VLC库路径,需在import vlc之前
os.environ['PYTHON_VLC_MODULE_PATH'] = "./vlc-3.0.16"
import vlc
import ctypes
import time
import sys
import cv2
import numpy
import datetime
#import PIL
from PIL import Image
vlcInstance = vlc.Instance()
# 记得换url,最好也和上面一样进行测试一下
url = "cc 00_00_02-00_01_03.mp4"
m = vlcInstance.media_new(url)
mp = vlc.libvlc_media_player_new_from_media(m)
# ***如果显示不完整,调整以下宽度和高度的值来适应不同分辨率的图像***
video_width = 1920
video_height = 1080
size = video_width * video_height * 4
buf = (ctypes.c_ubyte * size)()
buf_p = ctypes.cast(buf, ctypes.c_void_p)
VideoLockCb = ctypes.CFUNCTYPE(ctypes.c_void_p, ctypes.c_void_p, ctypes.POINTER(ctypes.c_void_p))
@VideoLockCb
def _lockcb(opaque, planes):
# print("lock", file=sys.stderr)
planes[0] = buf_p
#videosave
fps = 15
size = (video_width, video_height)
#定义编码格式mpge-4
fourcc = cv2.VideoWriter_fourcc('M', 'P', '4', '2')
#定义视频文件输入对象
now_begin = int(time.time())
@vlc.CallbackDecorators.VideoDisplayCb
def _display(opaque, picture):
now_fps_begin = int(round(1000*time.time()))
img = Image.frombuffer("RGBA", (video_width, video_height), buf, "raw", "BGRA", 0, 1)
opencv_image = cv2.cvtColor(numpy.array(img), cv2.COLOR_RGB2BGR)
cv2.imshow('image', opencv_image)
now_fps_end = int(round(1000*time.time()))
fps_now = 60-now_fps_end now_fps_begin
if fps_now>0:
outVideo.write(opencv_image)
cv2.waitKey(fps_now)
#print(fps_now)
vlc.libvlc_video_set_callbacks(mp, _lockcb, None, _display, None)
mp.video_set_format("BGRA", video_width, video_height, video_width * 4)
now_begin1 = int(time.time())
time_Distance = 0
#转换为其他日期格式,如:"%Y-%m-%d %H:%M:%S"
timeArray = time.localtime(now_begin1)
otherStyleTime = time.strftime("%Y_%m_%d_%H_%M_%S", timeArray)
AVI = '.avi'
AVI_Name = otherStyleTime ".avi"
print(AVI_Name )
outVideo = cv2.VideoWriter(AVI_Name,fourcc,fps,size)
while time_Distance<=60:
mp.play()
now_end = int(time.time())
time_Distance = now_end - now_begin1
#print(time_Distance)
time.sleep(1)
好例子网口号:伸出你的我的手 — 分享!
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论