zoukankan      html  css  js  c++  java
  • web flash推流录制测试研究

    用flash as3写了一段推流测试demo,参考srs_publisher和simplest_as3_rtmp_streamer。
    推流到srs2服务器,录制为flv文件。
    测试一轮结果如下:

    Web Flash推上来的流,经过srs录制为flv。
    srs设置jitter_time full; dvr_plan segment; dvr_duration 180; 实际录制180s。
    flowplayer 可以播放服务器flv文件 有声音没视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    jwplayer 可以播放服务器flv文件 有声音没视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    sewiseplayer 可以播放服务器flv文件 有声音没视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 seek功能可后期添加。
    strobe 可以播放服务器flv文件 有声音有视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    srs设置jitter_time zero;貌似也可以,笔记本测试过。

    srs设置jitter_time off; dvr_plan session;
    flowplayer 可以播放服务器flv文件 有声音没视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    jwplayer 可以播放服务器flv文件 有声音没视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    sewiseplayer 可以播放服务器flv文件 有声音没视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    strobe 可以播放服务器flv文件 有声音有视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。

    srs设置jitter_time zero; dvr_plan session;
    flowplayer 可以播放服务器flv文件 有声音没视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    jwplayer 可以播放服务器flv文件 有声音有视频 长宽比不对 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    sewiseplayer 可以播放服务器flv文件 有声音有视频 有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。
    strobe 可以播放服务器flv文件 有声音有视频 没有时间标签 不支持seek。(ffmpeg,yamdi,flvmeta) 修复meta后 正常播放 有时间标签 支持seek。

    一段时间以来都没有解决这个问题,以为就是这样的。也和网友讨论过这个问题,被当做srs feature处理了。
    这几天研究录制的文件,发现录制的flv和其他平台录制的flv格式不太一样。
    使用FlvParse分析一下录制flv文件的结构,发现:
    经过ffmpeg转化的flv,有字段onMetaData,而web flash推流录制发flv没有。

      

    经过查找接口,发现as3也有onMetaData接口,我并未调用。添加如下代码解决:

     1 // add metaData for stream
     2     var metaData:Object = new Object();
     3     metaData.title = "SptCallCenter";
     4     metaData.author = "Jeffer";
     5 metaData.width = av_hd_width;
     6     metaData.height = av_hd_height;
     7     metaData.videodatarate = av_hd_Vbitrate/1000;
     8     metaData.framerate = av_hd_fps;
     9 //send metadata
    10     metaData.videocodecid = 7;
    11     metaData.audiosamplerate = 16000;
    12     metaData.audiocodecid = 4;
    13     media_stream.send("@setDataFrame", "onMetaData", metaData); 
  • 相关阅读:
    每天进步一点点之查找
    每天进步一点点之堆栈思想
    每天进步一点点之大端存储和小端存储
    每天进步一点点之线性表的考察
    每天进步一点点之出栈顺序考点
    React Native 混合开发与实现
    谈谈JavaScript异步代码优化
    谈谈前端异常捕获与上报
    vue插件编写与实战
    vue项目构建与实战
  • 原文地址:https://www.cnblogs.com/zzugyl/p/8862766.html
Copyright © 2011-2022 走看看