说明:参考文献(官方文档):https://developer.apple.com/library/content/documentation/GraphicsImaging/Reference/CoreImageFilterReference/index.html#//apple_ref/doc/filter/ci/CIAdditionCompositing
版权:POCO所有
本文没有对CICategoryTileEffect 类有过多的描述
滤镜的原理
不同类有不同的原理,
最基本的是用5*4的颜色矩形来处理每一个像素点
有的是获取所有的点,根据点的颜色来判断,是否让它透明,这样子可以做一些扣图
有的是利用2-3张图片 来做一些炫酷的特效
有的是生成二维码的 有的是生成一个光晕的
然后浮雕的原理是用自己的rgb的值-相邻的点的rgb的值+128 这样子的算法会导致要2个点颜色相差比较大效果才明显
有一些的原理是 获取到一个区域 然后对这个区域 做一些特性 或取该区域的颜色值 生成有规律的图片
调用滤镜接口
CIFilter *filter = [CIFilter filterWithName:@"滤镜的名字"]];
//一般都会让你输入一张图片
CIImage * a =[[CIImage alloc] initWithImage:self.showImage];
[self filter:filter setValue:a forKey:kCIInputImageKey];
//给滤镜的参数赋值就用这句代码
[filter setValue:<#(nullable id)#> forKey:<#(nonnull NSString *)#>];
//以下2句为查看该滤镜的所有属性
//filter = [CIFilterfilterWithName:@"滤镜的名字"];
//NSLog(@"----%@",[filter attributes]);
CIImage *outputImage = [filter outputImage];
CIContext *context = [CIContext contextWithOptions:nil];
UIImage *showImage = [UIImage imageWithCGImage:[context createCGImage:outputImage fromRect:outputImage.extent]];
CGImageRef ref = [showImage CGImage];
//把得到的图片赋值到需要展示的imageView上
self.showImageView.image = showImage;
//调用c的接口都要release 不然会占内存
CGImageRelease(ref);
//防止输入的key有误
- (void)filter:(CIFilter *)filter setValue:(id)value forKey:(NSString *)key {
if ([filter.inputKeys containsObject:key]) {
[filter setValue:value forKey:key];
}
}
比较特殊的
这个类的滤镜 有几个需要用到c++的代码 是用来取颜色范围的
还有这个类 是可以自定义颜色矩形的
这个是7*7的 参数不能直接传数组,要用一个指针指向该数组 然后传指针做参数
滤镜常见的赋值