GPUImage

- (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;

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 概述 GPUImage是一个著名的图像处理开源库,它让你能够在图片、视频、相机上使用GPU加速的滤镜和其它特效。与...
    ghost_7fa3阅读 7,756评论 0 2
  • 最近在研究自定义相机,关于滤镜的组合与叠加,于是利用GPUImage开发了一个demo,用于实现多个滤镜的组合与即...
    潇潇潇潇JJ阅读 1,514评论 0 1
  • GPUImage作为一个很强大很强大很强大的图形处理工具,可以处理图片,视频.超爽的. 废话不多说,第一天大概我就...
    今年27阅读 287评论 0 0
  • 本篇主要讲解GPUImage底层是如何渲染的,GPUImage底层使用的是OPENGL,操控GPU来实现屏幕展示 ...
    wo不懂阅读 2,276评论 4 4
  • GPUImage的简单使用 GPUImage 是一个开源的图像处理库,提供了非常多的滤镜效果来加工图片。GPUIm...
    困惑困惑困惑阅读 455评论 0 1