在iOS应用中,有一类应用很受广大妹纸们的青睐,那就是美图类应用。大家都喜欢在自拍后给照片加一个滤镜效果,让照片看起来更加有“文艺范”。在iOS内置框架中,为我们提供了一套十分丰富的滤镜效果。
滤镜:->给图像添加效果
介绍:1.框架介绍
1)CoreImage
(2)是一个图像框架 它基于OpenGL顶层创建 底层则用着色器来处理图像
(3)它利用了GPU基于硬件加速来处理图像
(4)CoreImage中有很多滤镜
(5)它们能够一次给予一张图像或者视频帧多种视觉效果 -> 滤镜链
(6)而且滤镜可以连接起来组成一个滤镜链 把滤镜效果叠加起来处理图像
2.类的介绍
1.CIImage:保存图像数据的类 CGImageRef->图像中的数据
2.CIFilter:滤镜类 图片属性进行细节处理的类 它对所有的像素进行操作 用键-值(KVC)来设置
3.CIContext:上下文是实现对图像处理的具体对象 ->滤镜对象输出的图像并不是合成之后的图像 需要使用图像处理的上下文 合并 输出的图像
3.效果介绍 100+效果可以通过attributes查找需要设置的参数内容
按效果分类:
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⃣️查询效果分类里面 的效果 filterNamesInCategory:<#(nullable NSString *)#>
2⃣️使用步骤:
1.实例CIImage ->首先把UIImage ->CHImageRef ->CIImage
2.创建CIFilter滤镜并给滤镜设置属性 属性通过kvc 来设置
3.创建CIContext上下文 合并
4.合并绿净输出的图像
5.赋给UIImageView对象显示
6.如果想使用滤镜链 可以再次叠加效果
代码展示:
首先使用滤镜设置图片效果,需要创建一个imageView
imageView = [[UIImageView alloc]initWithFrame:self.view.frame];
imageView.contentMode =UIViewContentModeScaleAspectFit;
[self.view addSubview:imageView];
一个按钮选取本地手机里面的图片相册:
UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
button.frame = CGRectMake(100, 100, 80, 40);
[button setTitle:@"PHOTO" forState:UIControlStateNormal];
button.backgroundColor = [UIColor brownColor];
[button addTarget:self action:@selector(choosePic) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:button];
在这里只是单一的一部分效果 所以只是添加一个按钮展示效果:
UIButton *button1 = [UIButton buttonWithType:UIButtonTypeCustom];
button1.frame = CGRectMake(100, 150, 80, 40);
[button1 setTitle:@"Filter" forState:UIControlStateNormal];
button1.backgroundColor = [UIColor brownColor];
[button1 addTarget:self action:@selector(addColorFilter) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:button1];
调用本地相册的方法:
-(void)choosePic{ UIImagePickerController *picker = [[UIImagePickerController alloc]init]; picker.delegate = self; [self presentViewController:picker animated:YES completion:nil]; }//选择完图片调用- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary*)info{
//获得选中的图像
UIImage *chooseImage= info[UIImagePickerControllerOriginalImage];
//显示在视图控件上
imageView.image = chooseImage;
//让相册页面消失
[self dismissViewControllerAnimated:YES completion:nil];
NSLog(@"%@",info);
}
设置滤镜属性需要的主要步骤和方法:
//添加源图片
CIImage *inputImage = [CIImage imageWithCGImage:imageView.image.CGImage];
//创建一个滤镜
CIFilter *filter =[CIFilter filterWithName:@"CIColorMonochrome"];
//设置滤镜的属性
[filter setValue:inputImage forKey:kCIInputImageKey];
//设置滤镜的颜色
[filter setValue:[CIColor colorWithRed:1.0 green:0.5 blue:0.6 alpha:1] forKey:kCIInputColorKey];
//查询滤镜里面的属性
NSLog(@"%@",filter.attributes);
// NSLog(@"%@",[CIFilter filterNamesInCategory:kCICategoryColorEffect]);
CIImage *outputImage =filter.outputImage;
//创建CIContext上下文 合并源图片和滤镜
CIContext *context =[CIContext contextWithOptions:nil];
//合并滤镜输出的图像
CGImageRef imageRef = [context createCGImage:outputImage fromRect:outputImage.extent];
//赋给UIImageView对象显示
imageView.image =[UIImage imageWithCGImage:imageRef];