音视频

GPUImage之直播APP的实时美颜滤镜

2017-07-06  本文已影响988人  红茶绅士

相关类

整个事件响应链

GPUImageVideoCamera -> GPUImageFilterGroup -> GPUImageView

实现过程

懒加载相关类

//视频源
fileprivate lazy var camera : GPUImageVideoCamera? = GPUImageVideoCamera(sessionPreset: AVCaptureSessionPresetHigh, cameraPosition: .front)

//预览图层
fileprivate lazy var preview : GPUImageView = GPUImageView(frame: self.view.bounds)

//初始化滤镜
let bilateralFilter = GPUImageBilateralFilter()     //磨皮
let exposureFilter = GPUImageExposureFilter()       //曝光
let brightnessFilter = GPUImageBrightnessFilter()   //美白
let satureationFilter = GPUImageSaturationFilter()  //饱和

创建滤镜组GPUImageFilterGroup

//创建滤镜组
fileprivate func getGroupFilters() -> GPUImageFilterGroup {
    let filterGroup = GPUImageFilterGroup()
    
    //设置滤镜链接关系
    bilateralFilter.addTarget(brightnessFilter)
    brightnessFilter.addTarget(exposureFilter)
    exposureFilter.addTarget(satureationFilter)
    
    //设置group起始点 终点
    filterGroup.initialFilters = [bilateralFilter]
    filterGroup.terminalFilter = satureationFilter
    
    return filterGroup
}

设置GPUImageVideoCamera相关属性并将GPUImageFilterGroup添加到响应链

private func setupCamera() {
    //设置camera方向
    camera?.outputImageOrientation = .portrait
    camera?.horizontallyMirrorFrontFacingCamera = true
    
    //添加预览图层
    view.insertSubview(preview, at: 0)
    
    //获取滤镜组
    let filterGroup = getGroupFilters()
    
    //设置GPUImage的响应链
    camera?.addTarget(filterGroup)
    filterGroup.addTarget(preview)
    
    //开始采集视频
    camera?.startCapture()
}

注意事项

Demo地址

Demo扩展说明:

上一篇 下一篇

猜你喜欢

热点阅读