直播APP
l 直播原理
直播本质:实时推送/拉取过来的音视频数据
直播相关的协议:
l RTMP(实时消息的传输协议)
RTMP协议是一个互联网TCP/IP五层体系结构中的应用层协议
RTMP协议可以用来推送又可以用来直播
RTMP协议中基本的数据单元成为消息(Message)
RTMP协议在互联网传输数据的时候,消息会被拆分成更小的单元,成为消息块(Chunk)
二:FLV协议
FLV协议是在大块的视频帧和音频帧头部加入一些标记条信息。
FLV协议在延迟变现 和 大规模并发方面和成熟
FLV非常适合 手机端APP的直播协议
三:HLS
苹果推出的解决方案:
将视频分成5~10秒的视频小分片,然后用m3u8索引进行管理。
HLS在iphone和大部分Android手机浏览器上的支持非常给力,
常用的想QQ和微信朋友圈的URL分享。
什么是m3U8
VItamio操作:
Vitamio 能够流畅播放720P甚至1080P高清MKV,FLV,MP4,MOV,TS,RMVB等常见格式的视频,还可以在Android 上支持 MMS, RTSP, RTMP, HLS(m3u8) 等常见的多种视频流媒体协议,包括点播与直播。
Github下载地址:https://github.com/yixia/VitamioBundle
第一步在GitHub上下载Vitamio的依赖库,下载后的结构为:
之后将Vitamio文件夹作为Module导入到项目中。
将module导入到APP中,作为依赖库使用
或者直接在app的build.gradle中添加
将Vitamio的依赖库导入到APP中!
注意:最好是将Vitamio—res下的raw中的libarm.so so
文件复制到app res 下的raw中:
之后可能会出现的 问题是:显示api过期等问题,
学要在build,gradle中加入代码:
之后将defaultConfig中的targetSdkVersion设置为21 Vitamio的版本为4.0.0。此版本测试为21 不会出现问题!之后clear一下过程!编辑即可通过!!
清单文件的操作:
添加必要的权限:
<uses-permission android:name="android.permission.WAKE_LOCK"/>
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
导入actiivity
<activity
android:name="io.vov.vitamio.activity.InitActivity"
android:configChanges="orientation|screenSize|smallestScreenSize|keyboard|keyboardHidden|navigation"
android:launchMode="singleTop"
android:theme="@android:style/Theme.NoTitleBar"
android:windowSoftInputMode="stateAlwaysHidden"/>
XML布局的设置:
布局使用io.vov.vitamio.widget.VideoView中的VideoView,切记不要使用原始的VideoView。
Activity的操作:
1、 检测Vitamio框架是否可以使用
if(!LibsChecker.checkVitamioLibs(this)) {
return;
}
不建议使用模拟器进行测试,真机测试出现 闪退的情况(说明Vitamio不能使用)上面代码直接用Toast进行的是。
2、 初始化加载库文件
Vitamio.Initialized(getApplicationContext());
3、 判读初始化是否成功(模拟器部分显示不成功)
Vitamio.isInitialized(getApplicationContext());
返回值为boolean,true表示初始化成功,false表示初始化失败。
4、 设置播放的url地址
mVideoView.setVideoURI(Uri.parse(url));
5、 设置控制器(this表示系统知道的模式,可以自定义)
MediaControllercontroller = new MediaController(this);
videoView.setMediaController(controller);
实现的接口:
函数: