一鍵生成微信二維碼

<h3>引言</h3>

生成二維碼的步驟
導(dǎo)入CoreImage框架
通過(guò)濾鏡CIFilter生成二維碼

<h4>生成普通的二維碼</h4>

<pre>/** 生成一張普通的二維碼 */
+(UIImage )QRcodeToolgeneratedDataString:(NSString )dataString
imageViewWidth:(CGFloat)imageViewWidth;</pre>
創(chuàng)建生成二維碼的類方法
<pre>/

生成一個(gè)普通的二維碼

@param dataString 傳入要生成二維碼的數(shù)據(jù)
@param imageViewWidth 圖片的寬度

*/
+(UIImage *)QRcodeToolgeneratedDataString:(NSString *)dataString
imageViewWidth:(CGFloat)imageViewWidth
{
//通過(guò)濾鏡CIFilter生成二維碼

//1.創(chuàng)建過(guò)濾器
CIFilter  *filter=[CIFilter filterWithName:@"CIQRCodeGenerator"];

// 2.恢復(fù)默認(rèn)
[filter setDefaults];

// 3.給過(guò)濾器添加數(shù)據(jù)
NSData *data = [dataString dataUsingEncoding:NSUTF8StringEncoding];


// 4.通過(guò)KVO設(shè)置濾鏡inputMessage數(shù)據(jù)
[filter setValue:data forKeyPath:@"inputMessage"];
// 4.獲取輸出的二維碼
CIImage *outputImage = [filter outputImage];

return [QRcodeTool createNonInterpolatedUIImageFormCIImage:outputImage withSize:imageViewWidth];

}
</pre>

根據(jù)CIImage生成指定大小的UIImage

<pre>/** 根據(jù)CIImage生成指定大小的UIImage */

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

}
</pre>

生成一張帶有l(wèi)ogo的二維碼

<pre>
/**
生成一張帶有l(wèi)ogo的二維碼

@param dataString 傳入要生成二維碼的數(shù)據(jù)
@param logoimageName 圖片名字
@param logoScale logo相對(duì)于父視圖的縮放比(取值范圍:0-1取募,0供填,代表不顯示脓魏,1,代表與父視圖大小相同)

*/
+(UIImage *)QRcodeToolgeneratedLogoDataString:(NSString *)dataString
logoimageName:(NSString *)logoimageName
logoScale:(CGFloat)logoScale
{
// 1觅廓、創(chuàng)建濾鏡對(duì)象
CIFilter *filter = [CIFilter filterWithName:@"CIQRCodeGenerator"];

// 恢復(fù)濾鏡的默認(rèn)屬性
[filter setDefaults];

// 2、設(shè)置數(shù)據(jù)
NSString *string_data = dataString;
// 將字符串轉(zhuǎn)換成 NSdata (雖然二維碼本質(zhì)上是字符串, 但是這里需要轉(zhuǎn)換, 不轉(zhuǎn)換就崩潰)
NSData *qrImageData = [string_data dataUsingEncoding:NSUTF8StringEncoding];

// 設(shè)置過(guò)濾器的輸入值, KVC賦值
[filter setValue:qrImageData forKey:@"inputMessage"];

// 3涵但、獲得濾鏡輸出的圖像
CIImage *outputImage = [filter outputImage];

// 圖片小于(27,27),我們需要放大
outputImage = [outputImage imageByApplyingTransform:CGAffineTransformMakeScale(20, 20)];

// 4杈绸、將CIImage類型轉(zhuǎn)成UIImage類型
UIImage *start_image = [UIImage imageWithCIImage:outputImage];


// - - - - - - - - - - - - - - - - 添加中間小圖標(biāo) - - - - - - - - - - - - - - - -
// 5、開啟繪圖, 獲取圖形上下文 (上下文的大小, 就是二維碼的大小)
UIGraphicsBeginImageContext(start_image.size);

// 把二維碼圖片畫上去 (這里是以圖形上下文, 左上角為(0,0)點(diǎn)
[start_image drawInRect:CGRectMake(0, 0, start_image.size.width, start_image.size.height)];

// 再把小圖片畫上去
NSString *icon_imageName = logoimageName;
UIImage *icon_image = [UIImage imageNamed:icon_imageName];
CGFloat icon_imageW = start_image.size.width * logoScale;
CGFloat icon_imageH = start_image.size.height * logoScale;
CGFloat icon_imageX = (start_image.size.width - icon_imageW) * 0.5;
CGFloat icon_imageY = (start_image.size.height - icon_imageH) * 0.5;

[icon_image drawInRect:CGRectMake(icon_imageX, icon_imageY, icon_imageW, icon_imageH)];

// 6矮瘟、獲取當(dāng)前畫得的這張圖片
UIImage *final_image = UIGraphicsGetImageFromCurrentImageContext();

// 7瞳脓、關(guān)閉圖形上下文
UIGraphicsEndImageContext();

return final_image;

}</pre>

生成一張彩色的二維碼

<pre>+ (UIImage *)QRcodeToolgeneratedDataString:(NSString *)data backgroundColor:(CIColor *)backgroundColor mainColor:(CIColor *)mainColor
{
// 1、創(chuàng)建濾鏡對(duì)象
CIFilter *filter = [CIFilter filterWithName:@"CIQRCodeGenerator"];

// 恢復(fù)濾鏡的默認(rèn)屬性
[filter setDefaults];

// 2澈侠、設(shè)置數(shù)據(jù)
NSString *string_data = data;
// 將字符串轉(zhuǎn)換成 NSdata (雖然二維碼本質(zhì)上是字符串, 但是這里需要轉(zhuǎn)換, 不轉(zhuǎn)換就崩潰)
NSData *qrImageData = [string_data dataUsingEncoding:NSUTF8StringEncoding];

// 設(shè)置過(guò)濾器的輸入值, KVC賦值
[filter setValue:qrImageData forKey:@"inputMessage"];

// 3劫侧、獲得濾鏡輸出的圖像
CIImage *outputImage = [filter outputImage];

// 圖片小于(27,27),我們需要放大
outputImage = [outputImage imageByApplyingTransform:CGAffineTransformMakeScale(9, 9)];


// 4、創(chuàng)建彩色過(guò)濾器(彩色的用的不多)
CIFilter * color_filter = [CIFilter filterWithName:@"CIFalseColor"];

// 設(shè)置默認(rèn)值
[color_filter setDefaults];

// 5哨啃、KVC 給私有屬性賦值
[color_filter setValue:outputImage forKey:@"inputImage"];

// 6烧栋、需要使用 CIColor
[color_filter setValue:backgroundColor forKey:@"inputColor0"];
[color_filter setValue:mainColor forKey:@"inputColor1"];

// 7、設(shè)置輸出
CIImage *colorImage = [color_filter outputImage];

return [UIImage imageWithCIImage:colorImage];

}
</pre>

<h4>圖片效果</h4>

readme.png

<h3>Github地址:https://github.com/jwh1650715313/QRcode</h3>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末棘催,一起剝皮案震驚了整個(gè)濱河市劲弦,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌醇坝,老刑警劉巖邑跪,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件次坡,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡画畅,警方通過(guò)查閱死者的電腦和手機(jī)砸琅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)轴踱,“玉大人症脂,你說(shuō)我怎么就攤上這事∫В” “怎么了诱篷?”我有些...
    開封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)雳灵。 經(jīng)常有香客問(wèn)我棕所,道長(zhǎng),這世上最難降的妖魔是什么悯辙? 我笑而不...
    開封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任琳省,我火速辦了婚禮,結(jié)果婚禮上躲撰,老公的妹妹穿的比我還像新娘针贬。我一直安慰自己,他們只是感情好拢蛋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開白布桦他。 她就那樣靜靜地躺著,像睡著了一般谆棱。 火紅的嫁衣襯著肌膚如雪瞬铸。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天础锐,我揣著相機(jī)與錄音嗓节,去河邊找鬼。 笑死皆警,一個(gè)胖子當(dāng)著我的面吹牛拦宣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播信姓,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼鸵隧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了意推?” 一聲冷哼從身側(cè)響起豆瘫,我...
    開封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎菊值,沒想到半個(gè)月后外驱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體育灸,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年昵宇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了磅崭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡瓦哎,死狀恐怖砸喻,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蒋譬,我是刑警寧澤割岛,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站犯助,受9級(jí)特大地震影響蜂桶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜也切,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望腰湾。 院中可真熱鬧雷恃,春花似錦、人聲如沸费坊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)附井。三九已至讨越,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間永毅,已是汗流浹背把跨。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留沼死,地道東北人着逐。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像意蛀,于是被迫代替她去往敵國(guó)和親耸别。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

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

  • 一县钥、掃描 1秀姐、 ZBar ZBar在掃描的靈敏度上,和內(nèi)存的使用上相對(duì)于ZXing上都是較優(yōu)的若贮,但是對(duì)于 “圓角二...
    空白Null閱讀 1,055評(píng)論 0 2
  • 以前對(duì)iOS關(guān)于二維碼方面的知識(shí)掌握的比較零碎省有, 直到自己的一個(gè)關(guān)于支付方面iOS項(xiàng)目中有二維碼掃描界面痒留、二維碼生...
    獻(xiàn)國(guó)閱讀 1,011評(píng)論 0 2
  • 如何播放視頻 iOS提供了MPMoviePlayerController、MPMoviePlayerViewCon...
    JonesCxy閱讀 500評(píng)論 0 0
  • 1锥咸、對(duì)于表貼式PMSM電機(jī)而言狭瞎,Ld=Lq,因此最大轉(zhuǎn)矩控制就是當(dāng)Id=0時(shí)候的情況搏予,而對(duì)于內(nèi)置式PMSM電機(jī)而言...
    AronGao閱讀 917評(píng)論 0 0
  • 巴王宮內(nèi)有古衛(wèi)熊锭, 不疑異國(guó)來(lái)客賊。 相親一家享宮樂(lè)雪侥,共憶輝煌聚城樓碗殷。
    風(fēng)迷了沙閱讀 888評(píng)論 0 0