RTP视频传输播放延时(时间戳)
2012-06-03 14:13
246 查看
开发板OK6410+视频采集+wifi+VLC
视频传输采用RTP,实时传输视频,服务器端使用vlc播放,刚开始有3秒延时,播放时间越长延时越长,5分钟后竟达到10秒以后,分析代码,可能是时间戳造成,原时间代码部分:
timestamp_increse+=(unsigned int)(90000.0 / framerate); //framerate为帧率
网络上有人提出时间戳改为如下:
struct timeval tv;
gettimeofday(&tv , NULL);
timestamp_increse += (uint)((2.0*90000*tv.tv_usec + 1000000.0)/2000000);
但问题依旧
经测试时间戳采用设备时间,VLC播放基本正常,播放1小时后延时基本为3秒,代码如下:
struct timeval tv;
gettimeofday(&tv , NULL);
timestamp_increse = (uint)(90000.0 / (1000.0 / ((tv.tv_sec - tv_pre.tv_sec) * 1000.0 + (tv.tv_usec - tv_pre.tv_usec) / 1000.0)));
memcpy(&tv_pre, &tv, sizeof(tv_pre));
希望对遇到此问题的朋友有所帮助!
视频传输采用RTP,实时传输视频,服务器端使用vlc播放,刚开始有3秒延时,播放时间越长延时越长,5分钟后竟达到10秒以后,分析代码,可能是时间戳造成,原时间代码部分:
timestamp_increse+=(unsigned int)(90000.0 / framerate); //framerate为帧率
网络上有人提出时间戳改为如下:
struct timeval tv;
gettimeofday(&tv , NULL);
timestamp_increse += (uint)((2.0*90000*tv.tv_usec + 1000000.0)/2000000);
但问题依旧
经测试时间戳采用设备时间,VLC播放基本正常,播放1小时后延时基本为3秒,代码如下:
struct timeval tv;
gettimeofday(&tv , NULL);
timestamp_increse = (uint)(90000.0 / (1000.0 / ((tv.tv_sec - tv_pre.tv_sec) * 1000.0 + (tv.tv_usec - tv_pre.tv_usec) / 1000.0)));
memcpy(&tv_pre, &tv, sizeof(tv_pre));
希望对遇到此问题的朋友有所帮助!
相关文章推荐
- RTP视频传输播放延时(时间戳)
- RTP视频传输播放延时(时间戳)
- RTP视频传输播放延时(时间戳)
- RTP视频传输播放延时(时间戳)
- 基于itop4412在Linux最小系统下的 RTP传输H264视频VLC播放
- GStreamer资料整理(包括摄像头采集,视频保存,远程监控,流媒体RTP传输)
- RTP传输H264视频的技术要点
- 视频流传输协议RTP/RTCP/RTSP/HTTP的区别
- 实现RTP协议的H.264视频传输系统
- Android 实时视频采集/编码/传输/解码/播放—方案调研
- 嵌入式 视频流传输协议RTP/RTCP/RTSP/HTTP的区别
- 嵌入式 RTP通话:视频流(H.264)的传输
- 谈谈RTP传输中的负载类型和时间戳
- 用C#实现视频录像回放的时间播放条功能
- 音频、视频时间戳计算及每帧播放时间
- 使用jrtplib(RTP)传输H.264视频文件(1)
- 基于嵌入式Linux的视频采集系统8----基于RTP协议的实时传输模块
- 【我的解决方案】android2.3 播放网络视频时,截取任意时间点图像且保存下来
- RTP传输中的负载类型和时间戳
- 视频流传输协议RTP/RTCP/RTSP/HTTP的区别