概述:

好像有三个月没有更新博客了,年前实在是忙的累成狗啊。。。本想直播功能稳定了就没那么多事了,没想到又要搞魔法短视频功能,马丹,短视频玩成了花啊,撸起袖子干。

现在把我们项目中的直播SDK开源出来,我们是境外直播平台,百万用户,经过半年迭代,SDK已经相当稳定,大家可以放心使用。https://github.com/WangShuo1143368701/WSLiveDemo

这个sdk是我根据这个librestreaming修修改改出来的,由于改了太多的代码,用法已经不一样了。

之前写过一篇ffmpeg实战教程(十一)手把手教你实现直播功能,不依赖第三方SDK

是用ffmpeg实现的推流,但是在实际移动端直播项目中,推流是不适合用ffmpeg的。

特性:

支持视频录制和推流,录制视频推流可以同时进行

支持推流过程中实时截帧功能

支持推流过程中实时镜像功能,不会打断推流

支持设置关键帧间隔gop

支持动态设置码率,帧率

支持分开设置预览分辨率,编码的分辨率

支持gpu滤镜,并可以通过opengles绘制图像纹理来自定义滤镜。

支持设fbo滤镜组。

支持前后摄像头快速切换,不会打断推流。

支持后台推流,后台录制视频

美颜滤镜可动态调节磨皮,美白,红润。

兼容GPUImage,一行代码不用修改就可以直接使用GPUImage的滤镜。可参考demo。

关于美颜:

美颜滤镜可动态调节磨皮,美白,红润。你可以调出一个你喜欢的美颜滤镜。

关于截帧,镜像:

推流过程中可以实时截帧。

推流过程中可以实时调节镜像,不会打断推流。可以分别调节预览镜像,推流镜像。

关于性能:

采用相机回调纹理texture,OpenGL渲染后直接把textureID传给编码器的方案,中间没有数据格式转换,没有glReadPixel()函数耗时问题。所以性能较其它方案要好的多。缺点是必须是Android4.3以上。

关于使用:

1.所有常用API都在StreamLiveCameraView类中

android:id="@+id/stream_previewView"
android:layout_width="match_parent"
android:layout_height="match_parent"/>

2.初始化推流配置, StreamAVOption类里面有多种参数可配置,如不配置则使用默认值

/**
* 设置推流参数
*/
public void initLiveConfig() {
mLiveCameraView = (StreamLiveCameraView) findViewById(R.id.stream_previewView);
//参数配置 start
streamAVOption = new StreamAVOption();
streamAVOption.streamUrl = rtmpUrl;
//参数配置 end
mLiveCameraView.init(this, streamAVOption);
mLiveCameraView.addStreamStateListener(resConnectionListener);
//设置滤镜组
LinkedList files = new LinkedList<>();
files.add(new GPUImageCompatibleFilter(new GPUImageBeautyFilter()));
files.add(new GPUImageCompatibleFilter(new GPUImageAddBlendFilter()));
mLiveCameraView.setHardVideoFilter(new HardVideoGroupFilter(files));
}

3.开始推流录制 具体参考demo:

case R.id.btn_startStreaming://开始推流
if(!liveCameraView.isStreaming()){
liveCameraView.startStreaming(rtmpUrl);
}
break;
case R.id.btn_stopStreaming://停止推流
if(liveCameraView.isStreaming()){
liveCameraView.stopStreaming();
}
break;
case R.id.btn_startRecord://开始录制
if(!liveCameraView.isRecord()){
liveCameraView.startRecord();
}
break;
case R.id.btn_stopRecord://停止录制
if(liveCameraView.isRecord()){
liveCameraView.stopRecord();
}

关于集成:

方法2.

//Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
//Add the dependency
dependencies { compile compile 'com.github.WangShuo1143368701:WSLiveDemo:v1.5' }