• 请不要在回答技术问题时复制粘贴 AI 生成的内容
legendlee
V2EX  ›  程序员

想做移动端网页视频直播,请问除了 hls 之外还有其他可选方案吗?

  •  
  •   legendlee · Oct 8, 2015 via Android · 7055 views
    This topic created in 3896 days ago, the information mentioned may be changed or developed.
    暂且先排除 webRTC 。
    需要支持 ios 和 android 上的主流浏览器。
    如果现在没有的话,在不远的未来有没有?
    19 replies    2015-10-08 23:45:36 +08:00
    fengjianxinghun
        1
    fengjianxinghun  
       Oct 8, 2015
    webRTC 都排除。。。没有了。。
    haogefeifei
        2
    haogefeifei  
       Oct 8, 2015
    webRTC 排除。。
    jedyu
        3
    jedyu  
       Oct 8, 2015
    android 上开 hls 感觉 有点慢啊
    ljbha007
        4
    ljbha007  
       Oct 8, 2015
    你没说清楚是要上传还是下载

    MediaSource 就是干这个的 但是 iOS 不支持

    https://developer.mozilla.org/en-US/docs/Web/API/MediaSource
    dqh3000
        6
    dqh3000  
       Oct 8, 2015
    视频截成 1 秒钟一端然后用 video 放?

    完全自己设计一个视频格式然后用 websocket 传输用 webgl 渲染出来?

    怎么样怎么样?~~~
    ljbha007
        7
    ljbha007  
       Oct 8, 2015
    @dqh3000 如果这样就必须自己用 js 实现一个软解码 速度不一定够快
    lshero
        9
    lshero  
       Oct 8, 2015
    @ljbha007 见过别人用 websocket 和 Broadway( https://github.com/mbebenita/Broadway) 做的直播 demo 感觉很黑科技,而且只在计算机上见过演示,没有见过手机端的演示不知道效果怎么样
    ljbha007
        10
    ljbha007  
       Oct 8, 2015
    我发这几个都没有音频支持

    刚想到一个办法 楼上那个方案是行得通的
    把视频切成几秒到几十秒的片段 然后用 websocket 传回来 但是不用 js 写解码器 而是直接用 URL.createObjectURL 然后传给 video 标签并监听视频播放结束的事件
    结束时再把下一段缓存下来的视频用 URL.createObjectURL 生成 再传给 video 标签的 src 并且释放掉之前的视频和 ObjectURL 如此往复循环
    ljbha007
        11
    ljbha007  
       Oct 8, 2015
    @lshero 我试了 Broadway 在手机上也可以 iOS 上挺快的 只是没有声音
    lshero
        12
    lshero  
       Oct 8, 2015
    @ljbha007 直接传视频切片的 url 这样子和 hls 没啥区别了吧?

    关键是视频切片不提前缓冲的话 video 切换 src 的时候会卡啊 不知道用一个隐藏的 video 标签隐藏声音提前播放能不能预先加载进来。

    貌似音频解码也有 js 的解码器, http://audiocogs.org/codecs/aac/
    lshero
        13
    lshero  
       Oct 8, 2015
    @ljbha007 如果用 js 分别解码音视频不同步估计也没办法了
    coolzilj
        14
    coolzilj  
       Oct 8, 2015
    网页的话主流方案不都是 hls 吗, lz 是遇到什么问题。 WebRTC 稍微超前了些
    lshero
        15
    lshero  
       Oct 8, 2015
    @ljbha007 才发现是 URL.createObjectURL 脑子抽了一下
    legendlee
        16
    legendlee  
    OP
       Oct 8, 2015 via Android
    @jedyu 不仅慢,兼容性也不好,到处是坑。
    legendlee
        17
    legendlee  
    OP
       Oct 8, 2015 via Android
    @ljbha007 手机端怕性能不好,没敢用。
    dqh3000
        18
    dqh3000  
       Oct 8, 2015
    @lshero base64 也行吧,呵呵

    如果某些 js 解码器用了 webgl ,可能渲染性能不是问题,不过 mpeg 流量会不会高啊

    视频切割这个我觉得很可能坑很大的……例如不同浏览器对 video 的效果可能很不一样,不过如果用 cordova 封装什么的也许还可以
    POPOEVER
        19
    POPOEVER  
       Oct 8, 2015
    Periscope 用什么技术?
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1118 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 18:12 · PVG 02:12 · LAX 11:12 · JFK 14:12
    ♥ Do have faith in what you're doing.