概述:

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

现在把我们项目中的直播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' }

关于学习:

欢迎加入音视频交流群:364886309

Logo

致力于链接即构和开发者,提供实时互动和元宇宙领域的前沿洞察、技术分享和丰富的开发者活动,共建实时互动世界。

更多推荐