生成二維碼庶喜,是指根據(jù)給定的信息,將其按照二維碼的編碼方式生成一張圖片
原生二維碼:不對輸出的二維碼圖片進行任何加工處理兑障;
自定義二維碼:對輸出的二維碼圖片進行加工
1. 二維碼生成方式
> 從iOS7開始蘋果集成了二維碼的生成和讀取功能
> 此前被廣泛使用的zbarsdk目前不支持64位處理器,2015年2月1號起, 蘋果不允許不支持64位處理器的APP上架
2. 生成系統(tǒng)二維碼 <- OC
-
導(dǎo)入CoreImage框架(可選)
#import <CoreImage/CoreImage.h>
-
通過濾鏡CIFilter生成二維碼
// 1. 實例化二維碼濾鏡 CIFilter *filter = [CIFilter filterWithName:@"CIQRCodeGenerator"]; // 2. 恢復(fù)濾鏡的默認(rèn)屬性 [filter setDefaults]; // 3. 將字符串轉(zhuǎn)換成NSData NSData *data = [@"IOS筆記" 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];
3. 生成系統(tǒng)二維碼 <- swift
-
導(dǎo)入CoreImage框架
import CoreImage
-
通過濾鏡CIFilter生成二維碼
/** 友情提示: 學(xué)習(xí)實用技術(shù), 不要太在意語言, 把所有注意力, 放在步驟的實現(xiàn)上面 */ class GeneratorVC: UIViewController { @IBOutlet weak var inputTV: UITextView! @IBOutlet weak var qrCodeImageView: UIImageView! override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) { // 生成二維碼 // 1. 創(chuàng)建二維碼濾鏡 let filter = CIFilter(name: "CIQRCodeGenerator") // 1.1 恢復(fù)濾鏡默認(rèn)設(shè)置 filter?.setDefaults() // 2. 設(shè)置濾鏡的輸入內(nèi)容 // 2.1 通過KVC 給里面一個inputMessage實例變量賦值 // 輸入的內(nèi)容類型一定是NSData let content = inputTV.text let data = content.dataUsingEncoding(NSUTF8StringEncoding) filter?.setValue(data, forKey: "inputMessage") // 2.2 設(shè)置二維碼糾錯率(可選) // 糾錯率越高, 二維碼圖片,越復(fù)雜, 掃描識別的時間越長 filter?.setValue("M", forKey: "inputCorrectionLevel") // 3. 從濾鏡里面取出結(jié)果圖片 // 3.1 注意: 取出的圖片是ciimage, 并且大小是23* 23 所以需要我們單獨處理 // (23.0, 23.0) guard let outImage = filter?.outputImage else { return } // 3.2 圖片處理 // 使用這種方式, 可以把圖片放大處理, 而且保證不失真 let transform = CGAffineTransformMakeScale(20, 20) let resultImage = outImage.imageByApplyingTransform(transform) // 3.3 把CIImage轉(zhuǎn)換成為UIImage let image = UIImage(CIImage: resultImage) print(image.size) // 4. 顯示結(jié)果 qrCodeImageView.image = image } }