zoukankan      html  css  js  c++  java
  • 基于GPUImage的多滤镜rtmp直播推流

    之前做过开源videocore的推流改进:1)加入了美颜滤镜; 2) 加入了librtmp替换原来过于简单的rtmpclient;

    后来听朋友说,在videocore上面进行opengl修改,加入新的滤镜比较麻烦,IOS的滤镜最好的要算GPUImage了。

    自己就决定将多滤镜开源GPUImage来实现rtmp的直播推流;

    实现的方案:

    1,GPUImageMovieWriter进行rgba视频数据的输出。

    通过重写GPUImageMovieWriter,实现一个代理协议pixelBufferdelegate,讲gpu滤镜编码后的RGBA视频数据进行输出;

        self.movieWriter = [[GPUImageMovieWriterEx alloc] initWithMovieURL:movieURL size:CGSizeMake(360.0, 640.0)];

        self.movieWriter.encodingLiveVideo = YES;

        self.movieWriter.pixelBufferdelegate = self;

    2,初始化编码和rtmp模块

        self.rtmpSession = [[VCRtmpSession alloc] initWithVideoSize:VIDEO_SIZE_CIF fps:25 bitrate:BITRATE_CIF];

        [self.rtmpSession startRtmpSession:@"rtmp://192.168.1.104/live/123456"];

    3,设置想要的GPUImage滤镜

                self.filter = [[GPUImageBeautifyFilter alloc] init];

                [self.videoCamera addTarget:self.filter];

    现在就可以使用基于GPUImage的RTMP推流了,

    github代码地址: https://github.com/runner365/GPUImageRtmpPush

  • 相关阅读:
    每日思考(2020/07/13)
    每日思考(2020/07/12)
    每日思考(2020/07/11)
    每日思考(2020/07/10)
    每日思考(2020/07/09)
    每日思考(2020/05/12)
    Apache服务器的下载与安装
    知问前端——验证插件(二)
    知问前端——验证插件(一)
    知问前端——日历UI(三)
  • 原文地址:https://www.cnblogs.com/runner42/p/5672407.html
Copyright © 2011-2022 走看看