CoreImage

簡介

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.模糊處理

  1. 優(yōu)點: 模糊效果較好碉就,模糊程度的可調(diào)范圍很大盟广,可以根據(jù)實際的需求隨意調(diào)試
  1. 缺點: 耗時
  2. 需要導(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();
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末桨武,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子锈津,更是在濱河造成了極大的恐慌呀酸,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,576評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件琼梆,死亡現(xiàn)場離奇詭異性誉,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)茎杂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評論 3 399
  • 文/潘曉璐 我一進(jìn)店門错览,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人煌往,你說我怎么就攤上這事倾哺。” “怎么了刽脖?”我有些...
    開封第一講書人閱讀 168,017評論 0 360
  • 文/不壞的土叔 我叫張陵悼粮,是天一觀的道長。 經(jīng)常有香客問我曾棕,道長扣猫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,626評論 1 296
  • 正文 為了忘掉前任翘地,我火速辦了婚禮申尤,結(jié)果婚禮上癌幕,老公的妹妹穿的比我還像新娘。我一直安慰自己昧穿,他們只是感情好勺远,可當(dāng)我...
    茶點故事閱讀 68,625評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著时鸵,像睡著了一般胶逢。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上饰潜,一...
    開封第一講書人閱讀 52,255評論 1 308
  • 那天初坠,我揣著相機(jī)與錄音,去河邊找鬼彭雾。 笑死碟刺,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的薯酝。 我是一名探鬼主播半沽,決...
    沈念sama閱讀 40,825評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼吴菠!你這毒婦竟也來了者填?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,729評論 0 276
  • 序言:老撾萬榮一對情侶失蹤做葵,失蹤者是張志新(化名)和其女友劉穎占哟,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蜂挪,經(jīng)...
    沈念sama閱讀 46,271評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡重挑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,363評論 3 340
  • 正文 我和宋清朗相戀三年嗓化,在試婚紗的時候發(fā)現(xiàn)自己被綠了棠涮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,498評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡刺覆,死狀恐怖严肪,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情谦屑,我是刑警寧澤驳糯,帶...
    沈念sama閱讀 36,183評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站氢橙,受9級特大地震影響酝枢,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜悍手,卻給世界環(huán)境...
    茶點故事閱讀 41,867評論 3 333
  • 文/蒙蒙 一帘睦、第九天 我趴在偏房一處隱蔽的房頂上張望袍患。 院中可真熱鬧,春花似錦竣付、人聲如沸诡延。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽肆良。三九已至,卻和暖如春逸绎,著一層夾襖步出監(jiān)牢的瞬間惹恃,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評論 1 272
  • 我被黑心中介騙來泰國打工桶良, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留座舍,地道東北人。 一個月前我還...
    沈念sama閱讀 48,906評論 3 376
  • 正文 我出身青樓陨帆,卻偏偏與公主長得像曲秉,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子疲牵,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,507評論 2 359

推薦閱讀更多精彩內(nèi)容

  • CoreImage是iOS5中新加入的Objective-C的框架承二,提供了強(qiáng)大高效的圖像處理功能,用來對基于像素的...
    夢月落花LOVE閱讀 695評論 0 5
  • 老驥伏櫪纲爸,志在千里 前記 最近一直在研究圖像處理方面亥鸠,既上一篇iOS Quart2D繪圖之UIImage簡單使用后...
    半笑半醉間閱讀 4,408評論 0 14
  • 初衷 CoreImage系列是關(guān)于最近學(xué)習(xí)CoreImage處理圖片和視頻的一些總結(jié),如果有高手看到有錯誤的地方請...
    鐵甲陳小寶閱讀 1,190評論 0 10
  • 最近對圖像處理方面的東西比較感興趣识啦,剛好看了CoreImage這個強(qiáng)大的圖像處理框架负蚊,下面就跟大家分享一下。 首先...
    安靜SRR閱讀 1,972評論 2 7
  • 手指游戲14:兩只小八哥 兩只小八哥颓哮,住在山頂上家妆。(豎起食指) 一只叫叮叮,(一只手伸向前)冕茅,一只叫咚咚伤极,(一只手...
    八一胡閱讀 158評論 0 0