iOS开发之滤镜的使用技巧(CoreImage)

 

一、滤镜的内容和效果是比较多并且复杂的 ,学习滤镜需要技巧 如下:

两个输出语句解决滤镜的属性选择问题:

  • 1.查询效果分类中包含什么效果
    按住command 点击CIFilter 进入接口文件 找到第128行-148行全部都是 效果分类
  • 2.选择其中某一个分类拷贝
    NSLog -> [CIFilter filterNamesInCategory:刚才拷贝的分类]; -> 打印出来的 是这个分类包含的所有效果 -> 拷贝选择其中的某一个效果
  • 3.查询使用的效果中可以设置什么属性(KVC) attributes
    NSLog -> [CIFilter filterWithName:刚才拷贝选择其中的某一个效果].attributes ->得到这个滤镜所有可以设置的属性

    二、了解滤镜的相关介绍

    介绍

    • 1.框架介绍
      (1)CoreImage
      (2)是一个图像框架 它基于OpenGL顶层创建 底层则用着色器来处理图像
      (3)它利用了GPU基于硬件加速来处理图像
      (4)CoreImage中有很多滤镜
      (5)它们能够一次给予一张图像或者视频帧多种视觉效果 -> 滤镜链
      (6)而且滤镜可以连接起来组成一个滤镜链 把滤镜效果叠加起来处理图像
  • 2.类的介绍
    (1)CIImage:保存图像数据的类 CGImageRef->图像中的数据
    (2).CIFilter:滤镜类 图片属性进行细节处理的类 它对所有的像素进行操作 用键-值(KVC)来设置
    (3).CIContext:上下文是实现对图像处理的具体对象 -> 滤镜对象输出的图像并不是合成之后的图像 需要使用图像处理的上下文合并处理的图像
  • 3.效果介绍
  • 按效果分类:
    kCICategoryDistortionEffect 扭曲效果,比如bump、旋转、hole
    kCICategoryGeometryAdjustment 几何开着调整,比如仿射变换、平切、透视转换
    kCICategoryCompositeOperation 合并,比如源覆盖(source over)、最小化、源在顶(source atop)、色彩混合模式
    kCICategoryHalftoneEffect Halftone效果,比如screen、line screen、hatched
    kCICategoryColorAdjustment 色彩调整,比如伽马调整、白点调整、曝光
    kCICategoryColorEffect 色彩效果,比如色调调整、posterize
    kCICategoryTransition 图像间转换,比如dissolve、disintegrate with mask、swipe
    kCICategoryTileEffect 瓦片效果,比如parallelogram、triangle
    kCICategoryGenerator 图像生成器,比如stripes、constant color、checkerboard
    kCICategoryGradient 渐变,比如轴向渐变、仿射渐变、高斯渐变
    kCICategoryStylize 风格化,比如像素化、水晶化
    kCICategorySharpen 锐化、发光
  • kCICategoryBlur 模糊,比如高斯模糊、焦点模糊、运动模糊

    • 按使用场景分类:
      kCICategoryStillImage 用于静态图像
      kCICategoryVideo 用于视频
      kCICategoryInterlaced 用于交错图像
      kCICategoryNonSquarePixels 用于非矩形像素
      kCICategoryHighDynamicRange 用于HDR

      三、使用步骤

      1.实例CIImage -> 先把UIImage -> CGImageRef -> CIImage
      2.创建CIFilter滤镜并给滤镜设置属性(KVC)
      3.创建CIContext上下文
      4.初始化一个CGImageRef 输出图片对象 合并滤镜输出的图像
      5.赋给UIImage对象进行显示
      6.如果想使用滤镜链 可以再次添加效果

      四、一个实例解析 滤镜 滤镜链 保存图片

      代码示例:

      #import "ViewController.h"//宏定义  屏幕的宽
      #define SCREEN_WIDTH CGRectGetWidth([UIScreen mainScreen].bounds) //注意挂上代理
      @interface ViewController () <UIImagePickerControllerDelegate,UINavigationControllerDelegate>
      { UIImageView *myImageView;//接收图片的视图
      UIButton *photoButton;//从本地相册选择图片的按钮
      UIButton *filterButton;//添加滤镜的按钮
      UIButton *saveButton;//滤镜后保存到本地相册的按钮
      }
      @end
      @implementation ViewController
      - (void)viewDidLoad {
      [super viewDidLoad];
      //去除导航栏的高度 self.edgesForExtendedLayout = UIRectEdgeNone;
      //设置背景色 self.view.backgroundColor = [UIColor greenColor];
      // 创建按钮 NSArray *titleButtonList = @[@"photo",@"Filter",@"save"];
      for (int i=0; i<titleButtonList.count; i++) {
      UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
      button.frame = CGRectMake(20+80*i, 20, 60, 40);
      [button setTitle:titleButtonList[i] forState:UIControlStateNormal];
      button.tag = 10 +i ;
      [button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
      button.backgroundColor = [UIColor cyanColor];
      [self.view addSubview:button];
      } // 初始化图片视图
      myImageView = [[UIImageView alloc]initWithFrame:CGRectMake(20, 100, SCREEN_WIDTH-40, 300)];
      myImageView.backgroundColor = [UIColor cyanColor];
      [self.view addSubview:myImageView]; photoButton = [self.view viewWithTag:10];
      filterButton = [self.view viewWithTag:11];
      saveButton = [self.view viewWithTag:12]; // 给三个按钮添加触发事件
      [photoButton addTarget:self action:@selector(photoAction:) forControlEvents:UIControlEventTouchUpInside];
      // 滤镜按钮
      [filterButton addTarget:self action:@selector(filterAction:) forControlEvents:UIControlEventTouchUpInside];
      //保存滤镜后图片的按钮
      [saveButton addTarget:self action:@selector(saveAction:) forControlEvents:UIControlEventTouchUpInside]; }
      //选择图片
      - (void)photoAction:(UIButton *)sender{
      UIImagePickerController *pickerController = [[UIImagePickerController alloc]init];
      pickerController.delegate = self;
      [self presentViewController:pickerController animated:YES completion:nil];
      } //把图片放在图片视图上
      - (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary<NSString *,id> *)info{
      UIImage *image = info[UIImagePickerControllerOriginalImage];
      myImageView.image = image;
      [self dismissViewControllerAnimated:YES completion:nil];
      } //滤镜按钮的触发方法
      - (void)filterAction:(UIButton *)sender{ // 1.源图
      CIImage *inputImage = [CIImage imageWithCGImage:myImageView.image.CGImage];
      // 2.滤镜
      CIFilter *filter = [CIFilter filterWithName:@"CIColorMonochrome"];
      // NSLog(@"%@",[CIFilter filterNamesInCategory:kCICategoryColorEffect]);//注意此处两个输出语句的重要作用
      NSLog(@"%@",filter.attributes); [filter setValue:inputImage forKey:kCIInputImageKey]; [filter setValue:[CIColor colorWithRed:1.000 green:0.165 blue:0.176 alpha:1.000] forKey:kCIInputColorKey];
      CIImage *outImage = filter.outputImage;
      [self addFilterLinkerWithImage:outImage]; } //再次添加滤镜 形成滤镜链
      - (void)addFilterLinkerWithImage:(CIImage *)image{ CIFilter *filter = [CIFilter filterWithName:@"CISepiaTone"];
      [filter setValue:image forKey:kCIInputImageKey];
      [filter setValue:@(0.5) forKey:kCIInputIntensityKey]; // 在这里创建上下文 把滤镜和图片进行合并
      CIContext *context = [CIContext contextWithOptions:nil];
      CGImageRef resultImage = [context createCGImage:filter.outputImage fromRect:filter.outputImage.extent];
      myImageView.image = [UIImage imageWithCGImage:resultImage]; } //保存滤镜后的图片到本地相册
      - (void)saveAction:(UIButton *)sender{
      UIImageWriteToSavedPhotosAlbum(myImageView.image, self, @selector(image:didFinishSavingWithError:contextInfo:), nil);
      } //保存成功调用的方法
      - (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo{
      NSLog(@"保存成功");
      }
      @end
    • 2015年的苹果WWDC大会给着迷于Core Image Filters的开发者带来了一些好消息。(这次大会上)不仅有很多的滤镜,例如由MetalPerformanceShaders支持的模糊滤镜和卷积滤镜,在性能上表现出一些惊人的提升,而且苹果公司已经在iOS和OSX平台上都实现了相同性能的可用图像滤镜。

      这也给了iOS新的图像滤镜,以至于我都等不及把它加到我自己的Nodality应用里面了。这同时也也意味着代码和功能可以在类和设备上分享,我已经在设想一个Nodality的桌面版本了。

      那么,这些新滤镜是神马玩意? 这么说吧,CIFilter这个类里有类方法filterNamesInCategories(),用来返回一个包含所有可用滤镜的数组。下面快速浏览一下iOS8和9之间的差异吧:

      • CIAreaAverage       - 返回一个单像素图像,其中包含一块颜色区内的平均颜色。

      • CIAreaMaximum       - 返回一个单像素图像,其中包含一块颜色区内最大的颜色成分。

      • CIAreaMaximumAlpha    - 返回一个单像素图像,其中包含颜色区中最大透明度的颜色矢量。

      • CIAreaMinimum       - 返回一个单像素图像,其中包含颜色区中最小颜色成分。

      • CIAreaMinimumAlpha    - 返回一个单像素图像,其中包含颜色区内的最小透明度的颜色矢量。

      • CIBoxBlur          - 在一个矩形内使得图像模糊化。

      • CICircularWrap       - 用一个透明的圆圈环绕图像。

      • CICMYKHalftone       - 创建一个颜色,使得源图像呈半色调,在白色页面中使用使用青色,品红色,黄色和墨色。

      • CIColumnAverage       - 返回一个高为1像素的图像,包含每个扫描列的平均颜色。

      • CIComicEffect        - 像漫画书一样勾勒(图像)边缘,并应用半色调效果。

      • CIConvolution7X7      - 用一个7x7旋转矩阵来调整像素值。

      • CICrystallize        - 通过汇集源像素的颜色值,创建多边形色块。

      • CIDepthOfField        - 模拟一个场景深入的效果。

      • CIDiscBlur          - 在一个圆盘形状内模糊化图像。

      • CIDisplacementDistortion  - 将第二图像的灰度值应用到第一图像。

      • CIDroste             - 用类似M.C.埃舍尔绘图方式递归地绘制图像的一部分。

      • CIEdges              - 用颜色显示图像的边缘。

      • CIEdgeWork            - 产生一个黑白风格的类似木块切口的图像。

      • CIGlassLozenge         - 创建一个菱形滤镜,并扭曲滤镜位置的图像。

      • CIHeightFieldFromMask     - 产生一个连续的三维物体,一个阁楼形的灰场。

      • CIHexagonalPixellate      - 用所替换的像素映射彩色六边形的图像。

      • CIKaleidoscope          - 从源图像中通过将12路对称,产生一个五颜六色的图象。

      • CILenticularHaloGenerator   - 模拟闪光灯效果。

      • CILineOverlay           - 创建草图,用黑色勾勒出图像的边缘。

      • CIMedianFilter           - 计算一组邻近像素的平均数,然后用平均数替代每个像素的值。

      • CINoiseReduction          - 通过降低噪声的限定值来降低噪音。

      • CIOpTile               - 先分割图像,施加一些指定的缩放和旋转,然后拼接图像,形成的艺术化的表现。

      • CIPageCurlTransition       - 使用翻页效果从一个图像转换到另一个图像,翻卷后显示新的图像。

      • CIPageCurlWithShadowTransition  - 使用翻页效果从一个图像转换到另一个图像,翻卷后显示新的图像。

      • CIParallelogramTile         - 展示一个在平行四边形内的图像。

      • CIPassThroughColor

      • CIPassThroughGeom

      • CIPDF417BarcodeGenerator

      • CIPointillize              - 呈现一个pointillistic风格的源图像。

      • CIRippleTransition          - 图像创建一个圆形波从中心点向外扩大,在波形里显示新图像。

      • CIRowAverage              - 返回1个像素高的图像,其中包含每行扫描的平均颜色。

      • CIShadedMaterial            - 从一个高度场产生一个阴影图像。

      • CISpotColor               - 用色点替换颜色范围。

      • CISpotLight               - 图像使用一个方向聚光灯效果呈现。

      • CIStretchCrop              - 图像通过拉伸和或裁剪以适合目标尺寸。

      • CISunbeamsGenerator          - 图像呈现阳光照射的效果。

      • CITorusLensDistortion         - 创建环形滤镜,并扭曲透镜位置的图像。

      • CITriangleTile             - 截取图像的一个三角形部分映射到一个三角形区域,然后平铺展示。

 
 

iOS开发 滤镜的使用的更多相关文章

  1. iOS开发系列--打造自己的“美图秀秀”

    --绘图与滤镜全面解析 概述 在iOS中可以很容易的开发出绚丽的界面效果,一方面得益于成功系统的设计,另一方面得益于它强大的开发框架.今天我们将围绕iOS中两大图形.图像绘图框架进行介绍:Quartz ...

  2. 转载:iOS开发之让你的应用“动”起来

    在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌.在这里你可以看到iOS中如何使用图层精简非交互式绘图,如何通过核心动画创建基础动画.关键帧动画.动画 ...

  3. iOS开发系列--让你的应用“动”起来

    --iOS核心动画 概览 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌.在这里你可以看到iOS中如何使用图层精简非交互式绘图,如何通过核心动画创建 ...

  4. iOS开发使用半透明模糊效果方法整理

    虽然iOS很早就支持使用模糊效果对图片等进行处理,但尤其在iOS7以后,半透明模糊效果得到大范围广泛使用.包括今年最新发布的iOS8也沿袭了这一设计,甚至在OS X 10.10版Yosemite中也开 ...

  5. iOS开发常见BUG和一些小技巧(ps:耐心看完,很实用)

    [385][scrollView不接受点击事件,是因为事件传递失败] // // MyScrollView.m // Created by beyond on 15/6/6. // Copyright ...

  6. iOS开发200个tips总结(一)

    tip 1 :  给UIImage添加毛玻璃效果 func blurImage(value:NSNumber) -> UIImage { let context = CIContext(opti ...

  7. iOS - 开发类库

    开发类库   UI 项目名称 项目信息 1.MJRefresh 仅需一行代码就可以为UITableView或者CollectionView加上下拉刷新或者上拉刷新功能.可以自定义上下拉刷新的文字说明. ...

  8. iOS开发-定制多样式二维码

    iOS开发-定制多样式二维码   二维码/条形码是按照某种特定的几何图形按一定规律在平台(一维/二维方向上)分布的黑白相间的图形纪录符号信息.使用若干个与二进制对应的几何形体来表示文字数值信息. 最常 ...

  9. iOS开发-图片高斯模糊效果

    iOS开发的时候有的时候需要将图片设置模糊,或者通过点击下拉方法,去除模糊,一切都是为了应用更受用户欢迎,iOS7之后半透明模糊效果得到大范围使用的比较大,现在也可以看到很多应用局部用到了图片模糊效果 ...

随机推荐

  1. Flex 布局2

    Flex 布局2     你会看到,不管是什么布局,Flex往往都可以几行命令搞定. 我只列出代码,详细的语法解释请查阅<Flex布局教程:语法篇>.我的主要参考资料是Landon Sch ...

  2. select/poll/epoll on serial port

    In this article, I will use three asynchronous conferencing--select, poll and epoll on serial port t ...

  3. 论文阅读(Weilin Huang——【TIP2016】Text-Attentional Convolutional Neural Network for Scene Text Detection)

    Weilin Huang--[TIP2015]Text-Attentional Convolutional Neural Network for Scene Text Detection) 目录 作者 ...

  4. rc.local文件

    rc.local用于自启动一些服务. 查看有哪些自启动服务: cat /etc/rc.local

  5. Mysql数据库的使用总结之ERROR 1146 (42S02)

    在使用mysql数据库过程中,遇到了错误ERROR 1146 (42S02):Table doesn't exist,经过了两天,终于解决了这个问题.引起该错误的原因不同,对应的解决方法也不同.这里只 ...

  6. Android判断网路是否畅通加权限

    权限 <uses-permission android:name="android.permission.INTERNET"/> <uses-permission ...

  7. 突袭HTML5之WebGL 3D概述

    WebGL开启了网页3D渲染的新时代,它允许在canvas中直接渲染3D的内容,而不借助任何插件.WebGL同canvas 2D的API一样,都是通过脚本操纵对象,所以步骤也是基本相似:准备工作上下文 ...

  8. wex5 实战 登陆帐号更换与用户id一致性

    一 前言 关于用户登陆,注册,页面跳转,我讲了很多,都是页面框架级别的.有人问到这个问题,索性总结一下,今天是收尾最后一篇. 以往初学时的设计是: 1 注册 2 登陆 3 进入页面. 这种很简单,没有 ...

  9. Java数据结构之字符串模式匹配算法---KMP算法

    本文主要的思路都是参考http://kb.cnblogs.com/page/176818/ 如有冒犯请告知,多谢. 一.KMP算法 KMP算法可以在O(n+m)的时间数量级上完成串的模式匹配操作,其基 ...

  10. [已解决] MAVEN安装代码到本地库,安装jar, source, javadoc的方式

    mvn install:install-file -Dfile=a.jar -DgroupId=gid -DartifactId=aid -Dversion=0.0.1 -Dpackaging=jar ...