CoreImage滤镜的使用¶
1.概念¶
coreImage就是一个强大的框架,用这个框架我们可以通过调用简单的API使用框架所带的各种滤镜对图像进行处理,而不需要关心CPU/GPU等底层是如何对图像进行处理的。
coreImage的三个核心类:CIFilter 滤镜;CIContext:创建上下文;CIImage:构建图像数据的模型对象
1 2 3 4 5 | CIFilter:CIFilter是对图像数据进行处理的核心部分,我的理解是对指定的输入图像经过设置的参数进行一系列计算,然后组合成一个经过处理的输出图像数据,到目前(xcode6.0.2-beat 版,IOS8.0.2)为止,IOS自己带的有20个类型kCICategory,总计650种滤镜。只是指定滤镜类型而没有设置参数时,我们可以用setDefauts设置默认参数,滤镜就会根据默认参数对图像进行过滤处理。 CIContext:Core Image通过CIContext来渲染CIFilter产生的对象。滤镜的输入inputImage输出outputImage图像数据都是CIImage,CIImage图像数据不能直接渲染在CPU上,只有当真正将要显示的时候,才会通过第三个对象去渲染。这个对象就是CIContext;CIContext在初始化的时候需要一个字典,可以通过kCIContextUseSoftwareRenderer创建一个基于CPU的CIContext对象,默认是创建基于GPU的CIContext对象,不同之处在于GPU的CIContext对象处理起来会更快但是不能后台处理,如果需要保存到相册的话,一般建议使用CPU处理,以保证图像处理过程中退出后台也能正常处理完,而基于CPU的CIContext对象除了支持更大的图像以外,还能在后台处理。 CIImage:CIImage是一个模型对象,它保存能构建图像的数据,可以是图像的Data,可以是一个文件,也可以是CIFilter输出的对象。 |
2.使用¶
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | var beginImage = CIImage(image: image))//由UIImage创建一个CIImage; var filter:CIFilter = CIFilter(name: "CISepiaTone")//CIFilter的构造方法中包括了这个过滤器(CISepiaTone)的名字 filter.setValue(beginImage, forKey: kCIInputImageKey)//设置过滤器的图片 filter.setValue(0.5, forKey: kCIInputIntensityKey)//设置过滤器的图片透明度 let context = CIContext(options:[kCIContextUseSoftwareRenderer: true]) // CIContext(options:nil)//options为空时 默认为GPU处理,options为[kCIContextUseSoftwareRenderer: true]时 创建一个CPU处理的CIContext上下文对象 let outputImage = filter.outputImage let cgImage = context.createCGImage(outputImage!, from: outputImage!.extent) //createCGImage返回一个CGImage对象 let image = UIImage(CGImage:cgimg!) |
//条形码,二维码等也是通过CoreImage过滤生成
1 2 3 4 5 6 7 | // 二维码 let stringData = "abcdefg".data(using: String.Encoding.utf8) let filter = CIFilter(name: "CIQRCodeGenerator") //条形码name: "CICode128BarcodeGenerator" filter?.setDefaults() filter?.setValue(stringData, forKey: "inputMessage") let ciImage = filter?.outputImage let image = UIImage(CGImage:cgimg!) |
// 具体各种过滤name参考网站:https://developer.apple.com/library/content/documentation/GraphicsImaging/Reference/CoreImageFilterReference