簡介
CoreImage是IOS5中新加入的一個Objective-c的框架速兔,里面提供了強(qiáng)大高效的圖像處理功能预吆,用來對基于像素的圖像進(jìn)行操作與分析。IOS提供了很多強(qiáng)大的濾鏡(Filter),這些Filter提供了各種各樣的效果填具,并且還可以通過濾鏡鏈將各種效果的Filter疊加起來,形成強(qiáng)大的自定義效果匆骗,如果你對該效果不滿意劳景,還可以子類化濾鏡。
模糊效果匯總
二維碼
iOS二維碼
iOS圖像處理之Core Image
coreimage框架的簡單實用
CoreImage框架
coreImage的應(yīng)用
1.模糊處理
- 優(yōu)點: 模糊效果較好碉就,模糊程度的可調(diào)范圍很大盟广,可以根據(jù)實際的需求隨意調(diào)試
- 缺點: 耗時
- 需要導(dǎo)入: #import <CoreImage/CoreImage.h>
dispatch_async(dispatch_get_global_queue(0, 0), ^{
UIImage *sourceImage = [UIImage imageNamed:@"test"];
CIContext *context = [CIContext contextWithOptions:nil];
//CIImage
CIImage *ciImage = [[CIImage alloc] initWithImage:sourceImage];
//過濾器<有很多種, 在下邊打印的有>
CIFilter *blurFilter = [CIFilter filterWithName:@"CIGaussianBlur"];
//將圖片輸入到濾鏡中
[blurFilter setValue:ciImage forKey:kCIInputImageKey];
//設(shè)置模糊程度
[blurFilter setValue:@(5) forKey:@"inputRadius"];
NSLog(@"查看blurFilter的屬性--- %@",blurFilter.attributes);
//將處理之后的圖片輸出
CIImage *outCIImage = [blurFilter valueForKey:kCIOutputImageKey];
/** 獲取CGImage句柄
* createCGImage: 處理過的CIImage
* fromRect: 如果從處理過的圖片獲取frame會比原圖小, 因此在此需要設(shè)置為原始的CIImage.frame
*/
CGImageRef outCGImageRef = [context createCGImage:outCIImage fromRect:[ciImage extent]];
//獲取到最終圖片
UIImage *resultImage = [UIImage imageWithCGImage:outCGImageRef];
//釋放句柄
CGImageRelease(outCGImageRef);
dispatch_async(dispatch_get_main_queue(), ^{
blockSelf.imageView.image = resultImage;
});
});
2.二維碼的生成
參考:
git
之前用過的libqrencode是很早的時候用過的一個三方庫其中有一些核心算法是借助于c語言寫的,但是蘋果現(xiàn)在從IOS5之后就提供了生成二維碼的類-->CIFilter
// 1.創(chuàng)建濾鏡對象
CIFilter *filter = [CIFilter filterWithName:@"CIQRCodeGenerator"];
// 2.設(shè)置相關(guān)的信息
[filter setDefaults];
// 3.設(shè)置二維碼的數(shù)據(jù)
NSString *dataString = @"http://www.baidu.com";
NSData *data = [dataString dataUsingEncoding:NSUTF8StringEncoding];
// KVO 方式
[filter setValue:data forKeyPath:@"inputMessage"];
// 4.獲取輸出的圖片
CIImage *outputImage = [filter outputImage];
// 5.設(shè)置到imageView上即可
self.imageView.image = [UIImage imageWithCIImage:outputImage];
- 注意
- 二維碼上是不會有圖片的瓮钥,上面的圖片必須自己手動覆蓋到二維碼相對位置上
如果遮蓋住了二維碼的 邊上的3個邊框
- 二維碼上是不會有圖片的瓮钥,上面的圖片必須自己手動覆蓋到二維碼相對位置上
831339-d1fec1c3e6a2c60a.png
解決二維碼模糊問題--重繪像素點
- 根據(jù)繪圖筋量,將二維碼的每個像素繪制然后生成指定大小的圖片
831339-bbdaed88e6a34b84.png
- 方法:
/**
* 根據(jù)CIImage生成指定大小的UIImage
*
* @param image CIImage
* @param size 圖片寬度
*/
- (UIImage *)createNonInterpolatedUIImageFormCIImage:(CIImage *)image withSize:(CGFloat) size
{
CGRect extent = CGRectIntegral(image.extent);
CGFloat scale = MIN(size/CGRectGetWidth(extent), size/CGRectGetHeight(extent));
// 1.創(chuàng)建bitmap;
size_t width = CGRectGetWidth(extent) * scale;
size_t height = CGRectGetHeight(extent) * scale;
CGColorSpaceRef cs = CGColorSpaceCreateDeviceGray();
CGContextRef bitmapRef = CGBitmapContextCreate(nil, width, height, 8, 0, cs, (CGBitmapInfo)kCGImageAlphaNone);
CIContext *context = [CIContext contextWithOptions:nil];
CGImageRef bitmapImage = [context createCGImage:image fromRect:extent];
CGContextSetInterpolationQuality(bitmapRef, kCGInterpolationNone);
CGContextScaleCTM(bitmapRef, scale, scale);
CGContextDrawImage(bitmapRef, extent, bitmapImage);
// 2.保存bitmap到圖片
CGImageRef scaledImage = CGBitmapContextCreateImage(bitmapRef);
CGContextRelease(bitmapRef);
CGImageRelease(bitmapImage);
return [UIImage imageWithCGImage:scaledImage];
}
//
self.imageView.image = [self createNonInterpolatedUIImageFormCIImage:outputImage withSize:200];
二維碼顏色設(shè)置
遍歷每個像素,修改顏色
- (UIImage*) imageBlackToTransparent:(UIImage*) image
{
// 分配內(nèi)存
const int imageWidth = image.size.width;
const int imageHeight = image.size.height;
size_t bytesPerRow = imageWidth * 4;
uint32_t* rgbImageBuf = (uint32_t*)malloc(bytesPerRow * imageHeight);
// 創(chuàng)建context
CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
CGContextRef context = CGBitmapContextCreate(rgbImageBuf, imageWidth, imageHeight, 8, bytesPerRow, colorSpace,kCGBitmapByteOrder32Little | kCGImageAlphaNoneSkipLast);
CGContextDrawImage(context, CGRectMake(0, 0, imageWidth, imageHeight), image.CGImage);
// 遍歷像素
int pixelNum = imageWidth * imageHeight;
uint32_t* pCurPtr = rgbImageBuf;
//顏色修改部分:
for (int i = 0; i < pixelNum; i++, pCurPtr++)
{
if ((*pCurPtr & 0xFFFFFF00) == 0) // 將黑色變成透明
{
uint8_t* ptr = (uint8_t*)pCurPtr;
ptr[0] = 0;
ptr[1] = 0;
ptr[2] = 0;
ptr[3] = 0;
}
}
// 將內(nèi)存轉(zhuǎn)成image
CGDataProviderRef dataProvider = CGDataProviderCreateWithData(NULL, rgbImageBuf, bytesPerRow * imageHeight,ProviderReleaseData);
CGImageRef imageRef = CGImageCreate(imageWidth, imageHeight, 8, 32, bytesPerRow, colorSpace,kCGImageAlphaLast | kCGBitmapByteOrder32Little, dataProvider,NULL, true, kCGRenderingIntentDefault);
CGDataProviderRelease(dataProvider);
UIImage* resultUIImage = [UIImage imageWithCGImage:imageRef];
// 釋放
CGImageRelease(imageRef);
CGContextRelease(context);
CGColorSpaceRelease(colorSpace);
// free(rgbImageBuf) 創(chuàng)建dataProvider時已提供釋放函數(shù)碉熄,這里不用free
return resultUIImage;
}
/** 顏色變化 */
void ProviderReleaseData (void *info, const void *data, size_t size)
{
free((void*)data);
}
二維碼中心插入圖片---使用core graphics 繪制
UIGraphicsBeginImageContext(originImage.size);
[originImage drawInRect: (CGRect){ 0, 0, (originImage.size) }];
[whiteBG drawInRect: (CGRect){ brinkX, brinkY, (brinkSize) }];
[insertImage drawInRect: (CGRect){ imageX, imageY, (imageSize) }];
UIGraphicsEndImageContext();
二維碼背景圖--使用core graphics 繪制
UIGraphicsBeginImageContext(backgroundImage.size);
[backgroundImage drawInRect: (CGRect){ 0, 0, (backgroundImage.size) }];
[originImage drawInRect: (CGRect){ imageX, imageY, (imageSize) }];
UIImage * resultImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();