GPUImage

作者: baihualinxin | 来源:发表于2017-06-23 16:46 被阅读0次

- (IBAction)slider:(UISlider*)sender {

//1.取得滑块

UISlider*slider = (UISlider*)[self.viewviewWithTag:sender.tag];

//2.取得滑块的value

CGFloat vlaue = slider.value;

//3.value值显示

self.number.text= [NSStringstringWithFormat:@"%f",vlaue];

//4.选择滑块

switch(slider.tag) {

case100:

{//            亮度

GPUImageBrightnessFilter*brightness = [[GPUImageBrightnessFilteralloc]init];//创建滤镜对象

brightness.brightness= vlaue;//设置亮度 -1.0 to 1.0 默认 0.0

[brightnessforceProcessingAtSize:self.image.size];//设置要渲染的区域

[brightnessuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:brightness];//渲染图片并显示

}

break;

case101:

{//            曝光度

GPUImageExposureFilter*exposure = [[GPUImageExposureFilteralloc]init];//创建滤镜对象

exposure.exposure= vlaue;//设置亮度 -10 to 10 默认 0

[exposureforceProcessingAtSize:self.image.size];//设置要渲染的区域

[exposureuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:exposure];//渲染图片并显示

}

break;

case102:

{//            对比度

GPUImageContrastFilter*contrast = [[GPUImageContrastFilteralloc]init];//创建滤镜对象

contrast.contrast= vlaue;//设置对比度 0 to 4 默认 1

[contrastforceProcessingAtSize:self.image.size];//设置要渲染的区域

[contrastuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:contrast];//渲染图片并显示

}

break;

case103:

{//            饱和度

GPUImageSaturationFilter*saturation = [[GPUImageSaturationFilteralloc]init];//创建滤镜对象

saturation.saturation= vlaue;//设置饱和度 0 to 2 默认 1

[saturationforceProcessingAtSize:self.image.size];//设置要渲染的区域

[saturationuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:saturation];//渲染图片并显示

}

break;

case104:

{//            锐化

GPUImageSharpenFilter*sharpen = [[GPUImageSharpenFilteralloc]init];//创建滤镜对象

sharpen.sharpness= vlaue;//设置饱和度 -4 to 4 默认 0

[sharpenforceProcessingAtSize:self.image.size];//设置要渲染的区域

[sharpenuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:sharpen];//渲染图片并显示

}

break;

case105:

{//            形变

GPUImageTransformFilter*transform = [[GPUImageTransformFilteralloc]init];//创建滤镜对象

transform.transform3D= CATransform3DMakeScale(vlaue, vlaue, vlaue);//设置属性

[transformforceProcessingAtSize:self.image.size];//设置要渲染的区域

[transformuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:transform];//渲染图片并显示

}

break;

case106:

{//            高斯模糊

GPUImageGaussianBlurFilter*gaussianBlur = [[GPUImageGaussianBlurFilteralloc]init];//创建滤镜对象

gaussianBlur.texelSpacingMultiplier= vlaue;

[gaussianBlurforceProcessingAtSize:self.image.size];//设置要渲染的区域

[gaussianBluruseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:gaussianBlur];//渲染图片并显示

}

break;

case107:

{//            卡通效果

GPUImageToonFilter*sketch = [[GPUImageToonFilteralloc]init];//创建滤镜对象

sketch.quantizationLevels=10;

[sketchforceProcessingAtSize:self.image.size];//设置要渲染的区域

[sketchuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:sketch];//渲染图片并显示

}

break;

case108:

{//            球形倒立效果

GPUImageSphereRefractionFilter*glass = [[GPUImageSphereRefractionFilteralloc]init];//创建滤镜对象

glass.radius= vlaue;//设置球 半径

[glassforceProcessingAtSize:self.image.size];//设置要渲染的区域

[glassuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:glass];//渲染图片并显示

}

break;

case109:

{//            怀旧效果

GPUImageSepiaFilter*sepia = [[GPUImageSepiaFilteralloc]init];//创建滤镜对象

[sepiaforceProcessingAtSize:self.image.size];//设置要渲染的区域

[sepiauseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:sepia];//渲染图片并显示

}

break;

case110:

{//            反色效果

GPUImageColorInvertFilter*colorInvert = [[GPUImageColorInvertFilteralloc]init];//创建滤镜对象

[colorInvertforceProcessingAtSize:self.image.size];//设置要渲染的区域

[colorInvertuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:colorInvert];//渲染图片并显示

}

break;

case111:

{//            色彩丢失效果

GPUImageColorPackingFilter*colorPacking = [[GPUImageColorPackingFilteralloc]init];//创建滤镜对象

[colorPackingforceProcessingAtSize:self.image.size];//设置要渲染的区域

[colorPackinguseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:colorPacking];//渲染图片并显示

}

break;

case112:

{//            晕影效果

GPUImageVignetteFilter*vigette = [[GPUImageVignetteFilteralloc]init];//创建滤镜对象

vigette.vignetteStart=0;

[vigetteforceProcessingAtSize:self.image.size];//设置要渲染的区域

[vigetteuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:vigette];//渲染图片并显示

}

break;

case113:

{//            交叉线效果

GPUImageCrosshatchFilter*crosshatch = [[GPUImageCrosshatchFilteralloc]init];//创建滤镜对象

crosshatch.crossHatchSpacing= vlaue;

[crosshatchforceProcessingAtSize:self.image.size];//设置要渲染的区域

[crosshatchuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:crosshatch];//渲染图片并显示

}

break;

case114:

{//            哈哈镜效果

GPUImageStretchDistortionFilter*stretch = [[GPUImageStretchDistortionFilteralloc]init];//创建滤镜对象

stretch.center= CGPointMake(vlaue, vlaue);

[stretchforceProcessingAtSize:self.image.size];//设置要渲染的区域

[stretchuseNextFrameForImageCapture];//捕获图片效果

[selffilterWithObject:stretch];//渲染图片并显示

}

break;

default:

break;

}

}

相关文章

  • GPUImage2 的导入

    首先,GPUImage有3个版本分别是:GPUImage,GPUImage2,GPUImage3 GPUImage...

  • GPUImage概览

    读GPUImage源码,深入了解GPUImage原理及OpenGL ES。 关于GPUImage GPUImage...

  • GPUImage 解析

    GPUImage解析(一) —— 基本概览(一)GPUImage解析(二) —— 基本概览(二)GPUImage解...

  • GPUImage架构-思维导图

    GPUImage架构 参考文章: GPUImage架构

  • 视频滤镜

    GPUImage原生美颜 GPUImage原生美颜 步骤一:使用Cocoapods导入GPUImage步骤二:创建...

  • iOS GPUImage blog收集

    iOS GPUImage blog收集 GPUImage详解(简书博客) GPUImage(五):五种类型输入源(...

  • GPUImage(四):GPUImageFramebuffer

    GPUImage概览GPUImage(一):视频采集GPUImageVideoCameraGPUImage(二):...

  • iOS-DIY美颜相机

    本例是使用GPUImage开源框架,生成美颜相机。实时采集画面,进行美颜。 GPUImage GPUImage是开...

  • GPUImage源码分析与使用(一)

    GPUImage简介 GPUImage是链式编程,可以处理图片和视频,支持iOS和Mac。 GPUImage1.0...

  • iOS滤镜那些事儿

    一. GPUImage 框架的介绍及基本使用 1.GPUImage 的介绍 GPUImage是基于OpenGL E...

网友评论

      本文标题:GPUImage

      本文链接:https://www.haomeiwen.com/subject/pciccxtx.html