Android+Web视频直播装逼实现

一、前言

因为最近视频直播比较火,自己也想去了解,所以看了一些资料分享一下,说错了的请大家包容和指正。

二、实现原理

看图说话:

通过上图可以看到,所谓的视频直播其实就是通过录相设备将采集到视频数据以流的方式推送到服务器,然后我们观看直播的时候,以流的方式再从服务器拉取视频数据。当然这个过程还牵涉到一系列复杂的编码、丢包、抖动、延时……等一系列的技术难点,但是这些都不在我们今天的讨论范围。我们只想安静的做个简单的装逼直播而已,所以关于直播的原理,你可以粗略的理解为一个大木桶上有两根水管,一根进水,一根出水,就这么简单。

本次的技术实现方案,进水的水管(视频采集与推流)我选择通过Android手机(进一步证明我穷),而出水的水管(视频拉取与播放)我选择通过H5的Video标签来实现(因为我懒)。也就是说,这次的直播思路,其实就是通过你手机的摄像头,实时采集视频数据,并推送到好友手机上打开的H5页面中,实现视频直播。

而刚才提到的所有技术难点我们暂且都不去深究,因为从成本角度来考虑,我决定选择通过第三方的视频云服务来作为我们底层的技术支撑。经过简单的挑选之后,今天我们先暂且选择通过百度的LSS视频直播服务来实现(因为我穷)。

三、具体实现

首先,通过一张图来帮助大家简单了解一下LSS的使用步骤

                                                             LSS使用步骤
1、创建直播会话

根据上图,我们注册并开通LSS服务后,第一步要做的是创建直播会话。我们先来创建一个指定设置的直播会话,如图所示:


直播会话创建选项

这里大家可以看到我用一个红框标识了重点部分。此处建议大家选择一个合适的转码模板,因为默认的模板设置会导致最终视频直播时,服务器只做转发,保持输入分辨率与码率不变。这样有两个不妥之处:一是在用户实际观看时耗费的流量更大,延迟情况可能更加突出;二是在iPhone手机上,你会发现用HTML5当中默认的Video是无法直播的。这主要是因为iPhone手机默认对视频格式支持的问题。下面列出iPhone主要支持的视频格式:

1:H.264 视频:最高支持 1080p、60 fps、High Profile level 4.2 编码,其音频为 AAC-LC 格式、最高支持 160 Kbps、48kHz、立体声,文件封包格式为 .m4v、.mp4 和 .mov;

2:MPEG-4 视频:最高支持 2.5 Mbps、640 x 480 像素、30 fps、Simple Profile 编码,其音频为 AAC-LC 格式、最高支持每声道 160 Kbps、48kHz、立体声,文件封包格式为 .m4v、.mp4 和 .mov;

总而言之,在这里如果你想直接通过Video标签来观看后面的直播,这里就建议选择一个合适的转码模板,例如我只是用来装个逼,犯不着跟钱过不去,所以选择较低的640*360,而且实际上这个分辨率已经能在手机上取得不错的效果了。

2、实现Android端推流

首先下载LSS服务Adnroid推流端的SDK,然后做好相应的配置。在这里有一个地方要特别提一下,这个SDK包里面一共包括了如下几个文件:


SDK包含文件

关于jar文件的引入相信大家都不是问题。但关于so文件的引入,由于官方给的帮助文档还是基于Eclipse+ANT的引入方式(鄙视一个……),因此如果你使用的是Android Studio来作为开发工具,那么请按我下述的方法来操作:

1.在“src/main”目录中新建名为“jniLibs”的目录;

2.将so文件复制、粘贴到“jniLibs”目录内。

注:如果没有引用so文件,可能会在程序执行的时候加载类库失败,有类似如下的DEBUG提示——java.lang.UnsatisfiedLinkError: Couldn't load library xxxx from loader dalvik.system.PathClassLoader

引入了SDK后,接下来就要考虑实际的编码实现了。这里我废话就不多说了,直接示例程序的源代码,以供大家参考。具体请点击如下地址下载:

视频直播Android推送端

当你下载代码后,需要将程序当中的推流地址换成你自己的实际地址。具体关于推流与拉流的地址,你可以点击我们开始新创建的直播会话,进入会话详情页面,然后在这个地方获取。


获取视频推流与拉取地址

最终完成的APP效果如下图所示:


Android视频采集与推送效果图

3、实现Web端拉流播放

在Web端拉流播放有很多种实现方式,你可以自由选择使用第三方支持HLS的播放器。当然如果你希望能在直播时做一些更深层次的尝试,例如字幕、播放列表、广告、互动、直播授权等等,那么你也可以选择使用百度自家的T5播放内核。

而对于我来说仅仅为了装逼的需求,显然不足以推动我去继续花费时间,而且我需要的是别人能很轻松、没有任何限制的直接进入直播,不然我还怎么装逼?因此我选择了最简单粗暴的方式,就是直接做了一个适配移动端的H5页面,然后在里面使用了video标签,通过微信等方式直接分享给好友。关键代码如下:

<video src="http://gj0kf15c4z2aep308jr.exp.bcelive.com/lss-XXXXXXXXX/live.m3u8" height="300" width="100%" autoplay="autoplay"></video>

从个人隐私角度来考虑,所以我对上述拉流地址中的关键部分采用了XXXXXXXXX来代替,请大家不要在意这些小细节。实际使用的时候换上你自己的地址就好了。

4、装逼时刻

好了,接下来就是最后一步,你只需要把你刚做的移动端H5页面上传到你自己的虚拟空间或者云主机上,然后用微信扫描链接地址,并分享给你的女朋友(如果你真有的话……),或者你的好基友,就可以开启装逼模式了!切记,装逼莫太过,容易遭雷P……

四、一点感慨

随着信息技术的发展与开放,公有云技术的稳步提升,之前的一些技术难点,现在已经不再是困扰我们的瓶颈。从我个人来说,以视频直播为例,仅管我理解它的原理,也明白它的运行机制和关键的技术要点,但如果不是身在“云”的时代,让我从无到有搭建一套视频直播的架构并应用于实际生产,显示不是一朝一夕的事情。而现在半天的时间,借助云服务,我就能快速完成一个装逼的视频直播功能。感恩这个时代!这是一个属于我们技术人员的时代!






文/上善V若水(简书作者)
原文链接:http://www.jianshu.com/p/129e07b3e42f
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一: 使用javacv来实现,最终也是用过ffmpeg来进行编码和推流,javacv实现到可以直接接收摄像头的帧数据 需要自己实现的代码只是打开摄像头,写一个SurfaceView进行预览,然后实现PreviewCallback将摄像头每一帧的数据交给javacv即可 javacv地址:https://github.com/bytedeco/javacv demo地址:https://github.com/beautifulSoup/RtmpRecoder/tree/master 二: 使用Android自带的编码工具,可实现硬编码,这里有一个国内大神开源的封装很完善的的库yasea,第一种方法需要实现的Camera采集部分也一起封装好了,进行一些简单配置就可以实现编码推流,并且yasea目前已经直接支持摄像头的热切换,和各种滤镜效果 yasea地址(内置demo):https://github.com/begeekmyfriend/yasea 服务器 流媒体服务器我用的是srs,项目地址:https://github.com/ossrs/srs 关于srs的编译、配置、部署、在官方wiki中已经写的很详细了,并且srs同样是国内开发人员开源的项目,有全中文的文档,看起来很方便 这里有最基本的简单编译部署过程 Android直播实现(二)srs流媒体服务器部署 播放器 android端的播放使用vitamio,还是国内的开源播放器,是不是感觉国内的前辈们越来越屌了^~^! vitamio支持几乎所有常见的的视频格式和流媒体协议 vitamio地址(内置demo):https://github.com/yixia/VitamioBundle 这里使用的是yaesa库,先介绍一下直播实现的流程:

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值