ios二維碼

ios7之后系統(tǒng)框架已經(jīng)集成二維碼的生成與讀取, 這使開發(fā)變得方便很多, 并且會(huì)比第三方更加效率冒晰。

系統(tǒng)二維碼主要通過(guò)CIFilter的對(duì)象來(lái)完成

首先我們需要先導(dǎo)入這個(gè)類所在的框架:

#import <CoreImage/CoreImage.h>

生成二維碼

// 生成二維碼
-(UIImage *)creat2DcodeImage:(NSString *)url{
    // 1. 創(chuàng)建一個(gè)二維碼濾鏡實(shí)例(CIFilter)
    CIFilter *filter = [CIFilter filterWithName:@"CIQRCodeGenerator"];
    [filter setDefaults];     // 濾鏡恢復(fù)默認(rèn)設(shè)置
    
    // 2. 給濾鏡添加數(shù)據(jù)
    NSString *string = url;    //根據(jù)網(wǎng)址生成
    NSData *data = [string dataUsingEncoding:NSUTF8StringEncoding];
    // 使用KVC的方式給filter賦值
    [filter setValue:data forKeyPath:@"inputMessage"];
    
    // 3. 生成二維碼
    CIImage *image = [filter outputImage];
    
    // 4. 高清處理
    UIImage *newimg = [self createNonInterpolatedUIImageFormCIImage:image withSize:130.0];
    
    // 5. 添加logo
    // 開啟繪圖, 獲取圖片 上下文<圖片大小>
    UIGraphicsBeginImageContext(newimg.size);
    // 將二維碼圖片畫上去
    [newimg drawInRect:CGRectMake(0, 0, newimg.size.width, newimg.size.height)];
    // 將小圖片畫上去
    UIImage *smallImage = [UIImage imageNamed:@"動(dòng)畫1"];
    [smallImage drawInRect:CGRectMake((newimg.size.width - 50) / 2, (newimg.size.width - 50) / 2, 50, 50)];
    // 獲取最終的圖片
    UIImage *finalImage = UIGraphicsGetImageFromCurrentImageContext();
    // 關(guān)閉上下文
    UIGraphicsEndImageContext();
   
    return finalImage;    
}

//  注意:logo圖片不能太大, 否則會(huì)導(dǎo)致掃描不到二維碼中的信息同衣。

生成URL的二維碼

如果我們想要生成URL的二維碼, 只需要把上面第2步中的string替換為一個(gè)URL字符串即可。

二維碼高清處理

調(diào)用以下方法即可壶运,其中的參數(shù)size最好近似等于二維碼的邊長(zhǎng)乳怎。

- (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];
}

http://www.reibang.com/p/e8f7a257b612
http://www.cnblogs.com/QianChia/p/6213466.html *封裝掃描,識(shí)別前弯,生成
好用的第三方zxing

掃描二維碼

這里提供一些參考鏈接文章
http://www.code4app.com/ios/%E7%B3%BB%E7%BB%9FAPI%E6%89%AB%E6%8F%8F%E4%BA%8C%E7%BB%B4%E7%A0%81/4faa917a-ea5f-11e5-b1ca-00163e0606f4

http://www.code4app.com/ios/%E5%8E%9F%E7%94%9F%E5%AE%9E%E7%8E%B0%E7%9A%84%E4%BA%8C%E7%BB%B4%E7%A0%81%E3%80%81%E6%9D%A1%E5%BD%A2%E7%A0%81%E7%9A%84%E6%89%AB%E6%8F%8F/56a0de8eb5ad2ebe118b4962

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蚪缀,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子恕出,更是在濱河造成了極大的恐慌询枚,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浙巫,死亡現(xiàn)場(chǎng)離奇詭異金蜀,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)的畴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門渊抄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人丧裁,你說(shuō)我怎么就攤上這事护桦。” “怎么了煎娇?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵二庵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我缓呛,道長(zhǎng)催享,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任哟绊,我火速辦了婚禮因妙,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘票髓。我一直安慰自己攀涵,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布炬称。 她就那樣靜靜地躺著汁果,像睡著了一般。 火紅的嫁衣襯著肌膚如雪玲躯。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音跷车,去河邊找鬼棘利。 笑死,一個(gè)胖子當(dāng)著我的面吹牛朽缴,可吹牛的內(nèi)容都是我干的善玫。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼密强,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼茅郎!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起或渤,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤系冗,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后薪鹦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體掌敬,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年池磁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了奔害。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡地熄,死狀恐怖华临,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情端考,我是刑警寧澤银舱,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站跛梗,受9級(jí)特大地震影響寻馏,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜核偿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一诚欠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧漾岳,春花似錦轰绵、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至捅儒,卻和暖如春液样,著一層夾襖步出監(jiān)牢的瞬間振亮,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工鞭莽, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留坊秸,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓澎怒,卻偏偏與公主長(zhǎng)得像褒搔,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子喷面,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

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