V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
legendlee
V2EX  ›  程序员

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

  •  
  •   legendlee · 2015-10-08 14:57:53 +08:00 via Android · 6384 次点击
    这是一个创建于 3366 天前的主题,其中的信息可能已经有所发展或是发生改变。
    暂且先排除 webRTC 。
    需要支持 ios 和 android 上的主流浏览器。
    如果现在没有的话,在不远的未来有没有?
    19 条回复    2015-10-08 23:45:36 +08:00
    fengjianxinghun
        1
    fengjianxinghun  
       2015-10-08 14:59:41 +08:00
    webRTC 都排除。。。没有了。。
    haogefeifei
        2
    haogefeifei  
       2015-10-08 15:12:36 +08:00
    webRTC 排除。。
    jedyu
        3
    jedyu  
       2015-10-08 15:13:31 +08:00
    android 上开 hls 感觉 有点慢啊
    ljbha007
        4
    ljbha007  
       2015-10-08 15:37:06 +08:00
    你没说清楚是要上传还是下载

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

    https://developer.mozilla.org/en-US/docs/Web/API/MediaSource
    dqh3000
        6
    dqh3000  
       2015-10-08 15:44:02 +08:00
    视频截成 1 秒钟一端然后用 video 放?

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

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

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

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

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

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

    视频切割这个我觉得很可能坑很大的……例如不同浏览器对 video 的效果可能很不一样,不过如果用 cordova 封装什么的也许还可以
    POPOEVER
        19
    POPOEVER  
       2015-10-08 23:45:36 +08:00
    Periscope 用什么技术?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1053 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 33ms · UTC 19:37 · PVG 03:37 · LAX 11:37 · JFK 14:37
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.