用Swift寫微信二維碼

一.二維碼概述

1.二維碼的概念

二維碼, 是用某種特定的幾何圖形按一定規(guī)律在平面(二維方向上)分布的黑白相間的圖形記錄數(shù)據(jù)符號信息的;

2.二維碼的使用場景

● 信息獲瘸着(名片、地圖、WIFI密碼采盒、資料)

● 網(wǎng)站跳轉(zhuǎn)(跳轉(zhuǎn)到微博、手機(jī)網(wǎng)站树姨、網(wǎng)站)

● 廣告推送(用戶掃碼蹈集,直接瀏覽商家推送的視頻、音頻廣告)

● 手機(jī)電商(用戶掃碼、手機(jī)直接購物下單)

● 防偽溯源(用戶掃碼驯击、即可查看生產(chǎn)地烁兰;同時(shí)后臺(tái)可以獲取最終消費(fèi)地)

● 優(yōu)惠促銷(用戶掃碼,下載電子優(yōu)惠券徊都,抽獎(jiǎng))

● 會(huì)員管理(用戶手機(jī)上獲取電子會(huì)員信息沪斟、VIP服務(wù))

● 手機(jī)支付(掃描商品二維碼,通過銀行或第三方支付提供的手機(jī)端通道完成支付)


3.生成二維碼的方式

> 從iOS7開始集成了二維碼的生成和讀取功能

> 此前被廣泛使用的zbarsdk目前不支持64位處理器

4.生成二維碼的步驟

導(dǎo)入CoreImage框架 #import通過濾鏡CIFilter生成二維碼

> 1. 實(shí)例化二維碼濾鏡

CIFilter *filter = [CIFilter filterWithName:@"CIQRCodeGenerator"];

> 2. 恢復(fù)濾鏡的默認(rèn)屬性

[filter setDefaults];

> 3. 將字符串轉(zhuǎn)換成NSData

NSData *data = [@"小碼哥" dataUsingEncoding:NSUTF8StringEncoding];

> 4. 通過KVC設(shè)置濾鏡inputMessage數(shù)據(jù)

[filter setValue:data forKey:@"inputMessage"];

> 5. 獲得濾鏡輸出的圖像

CIImage *outputImage = [filter outputImage];

> 6. 將CIImage轉(zhuǎn)換成UIImage暇矫,并放大顯示

return [UIImage imageWithCIImage:outputImage scale:20.0 orientation:UIImageOrientationUp];

class GeneratorVC: UIViewController {@IBOutlet weak var inputTV: UITextView!@IBOutlet weak var qrCodeImageView: UIImageView!? ? override func touchesBegan(touches: Set, withEvent event: UIEvent?) {

/** 友情提示: 學(xué)習(xí)實(shí)用技術(shù), 不要太在意語言, 把所有注意力, 放在步驟的實(shí)現(xiàn)上面 */

let content = inputTV.text

// 生成二維碼

// 1. 創(chuàng)建二維碼濾鏡

let filter = CIFilter(name: "CIQRCodeGenerator")

// 1.1 恢復(fù)濾鏡默認(rèn)設(shè)置

filter?.setDefaults()

// 2. 設(shè)置濾鏡的輸入內(nèi)容

// 通過KVC 給里面一個(gè)inputMessage 賦值

// 輸入的內(nèi)容類型一定是NSData

let data = content.dataUsingEncoding(NSUTF8StringEncoding)

filter?.setValue(data, forKey: "inputMessage")

// 3. 從濾鏡里面取出結(jié)果圖片

// 3.1 注意: 取出的圖片是ciimage, 并且大小是23* 23 所以需要我們單獨(dú)處理

// (23.0, 23.0)

guard let outImage = filter?.outputImage else {

return

}

// 3.1 圖片處理

// 使用這種方式, 可以把圖片放大處理, 而且保證不失真

let transform = CGAffineTransformMakeScale(20, 20)

let resultImage = outImage.imageByApplyingTransform(transform)

// 把CIImage轉(zhuǎn)換成為UIImage

let image = UIImage(CIImage: resultImage)

print(image.size)

// 4. 顯示結(jié)果

qrCodeImageView.image = image

}

}


二.識別圖片二維碼

// 1. 創(chuàng)建一個(gè)二維碼探測器

let detector = CIDetector(ofType: CIDetectorTypeQRCode, context: nil, options: [CIDetectorAccuracy : CIDetectorAccuracyHigh])

// 2. 探測二維碼圖片的特征

guard let image = qrCodeImage.image else {

return

}

let imageCI = CIImage(image: image)

let features = detector.featuresInImage(imageCI!)

// 3. 處理識別到的特征值

print(features)

for feature in features {

if feature.isKindOfClass(CIQRCodeFeature) {

let qrCodeFeature = feature as! CIQRCodeFeature

print(qrCodeFeature.messageString)

// 繪制識別到的二維碼圖片

}

}

}

三.讀取二維碼

讀取二維碼需要導(dǎo)入AVFoundation框架

利用攝像頭識別二維碼中的內(nèi)容(模擬器不行)

實(shí)例化拍攝設(shè)備

AVCaptureDevice *device = [AVCaptureDevice defaultDeviceWithMediaType:AVMediaTypeVideo];

設(shè)置輸入設(shè)備

AVCaptureDeviceInput *input = [AVCaptureDeviceInput deviceInputWithDevice:device error:nil];

設(shè)置元數(shù)據(jù)輸出

3.1 實(shí)例化拍攝元數(shù)據(jù)輸出

AVCaptureMetadataOutput *output = [[AVCaptureMetadataOutput alloc] init];

3.2 設(shè)置輸出數(shù)據(jù)代理

[output setMetadataObjectsDelegate:self queue:dispatch_get_main_queue()];

3.3 設(shè)置掃描取景范圍(rectOfInterest 都是按照橫屏來計(jì)算的 所以當(dāng)豎屏的情況下 x軸和y軸要交換一下)

CGFloat screenW = [UIScreen mainScreen].bounds.size.width;

CGFloat screenH = [UIScreen mainScreen].bounds.size.height;

CGFloat scanW = screenW * 0.6;

CGRect scanRect = CGRectMake((screenW - scanW) * 0.5, (screenH - scanW) * 0.5, scanW, scanW);

output.rectOfInterest = CGRectMake(scanRect.origin.y / screenH, scanRect.origin.x / screenW, scanRect.size.height / screenH, scanRect.size.width / screenW);

3.4 設(shè)置掃描區(qū)域的邊框

UIView *scanV = [[UIView alloc] initWithFrame:scanRect];

[self.view addSubview:scanV];

scanV.layer.borderWidth = 2;

scanV.layer.borderColor = [UIColor redColor].CGColor;

添加拍攝會(huì)話

4.1 實(shí)例化拍攝會(huì)話

AVCaptureSession *session = [[AVCaptureSession alloc] init];

4.2 添加會(huì)話輸入

[session addInput:input];

4.3 添加會(huì)話輸出

[session addOutput:output];

4.3 設(shè)置輸出數(shù)據(jù)類型主之,需要將元數(shù)據(jù)輸出添加到會(huì)話后,才能指定元數(shù)據(jù)類型李根,否則會(huì)報(bào)錯(cuò)

[output setMetadataObjectTypes:@[AVMetadataObjectTypeQRCode]];

視頻預(yù)覽圖層

5.1 實(shí)例化預(yù)覽圖層

AVCaptureVideoPreviewLayer *preview = [AVCaptureVideoPreviewLayer layerWithSession:_session];

preview.videoGravity = AVLayerVideoGravityResizeAspectFill;

preview.frame = self.view.bounds;

5.2 將圖層插入當(dāng)前視圖

[self.view.layer addSublayer:preview];

self.previewLayer = preview;

啟動(dòng)會(huì)話

[_session startRunning];

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末槽奕,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子房轿,更是在濱河造成了極大的恐慌粤攒,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件囱持,死亡現(xiàn)場離奇詭異夯接,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)纷妆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進(jìn)店門盔几,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人掩幢,你說我怎么就攤上這事问欠。” “怎么了粒蜈?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵顺献,是天一觀的道長。 經(jīng)常有香客問我枯怖,道長注整,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任度硝,我火速辦了婚禮肿轨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蕊程。我一直安慰自己椒袍,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布藻茂。 她就那樣靜靜地躺著驹暑,像睡著了一般玫恳。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上优俘,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天京办,我揣著相機(jī)與錄音,去河邊找鬼帆焕。 笑死惭婿,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的叶雹。 我是一名探鬼主播财饥,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼折晦!你這毒婦竟也來了钥星?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤筋遭,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后暴拄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體漓滔,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年乖篷,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了响驴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,841評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡撕蔼,死狀恐怖豁鲤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情鲸沮,我是刑警寧澤琳骡,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站讼溺,受9級特大地震影響楣号,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜怒坯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一炫狱、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧剔猿,春花似錦视译、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鄙早。三九已至,卻和暖如春第美,著一層夾襖步出監(jiān)牢的瞬間蝶锋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工什往, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留扳缕,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓别威,卻偏偏與公主長得像躯舔,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子省古,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,781評論 2 354

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