iOS 原生實現(xiàn)掃描二維碼和條形碼功能限制掃描區(qū)域
現(xiàn)在蘋果iOS系統(tǒng)已經(jīng)原生支持了二維碼掃描的功能,使用原生來掃描需要導入AVFoundation。
掃描準備
一、獲取攝像設備:
device = AVCaptureDevice.defaultDevice(withMediaType: AVMediaTypeVideo)
二、創(chuàng)建輸入流
do {
try input = AVCaptureDeviceInput(device: device)
} catch let e as NSError {
print(e.localizedDescription)
}
三、創(chuàng)建輸出流
output = AVCaptureMetadataOutput() // 設置代理在主線程中刷新 output?.setMetadataObjectsDelegate(self, queue: DispatchQueue.main)
四、初始化連接對象
session = AVCaptureSession() // 高質(zhì)量采集率 session?.canSetSessionPreset(AVCaptureSessionPresetHigh) session?.addOutput(output) session?.addInput(input)
五、設置掃描區(qū)域
// 特別注意的地方:有效的掃描區(qū)域,定位是以設置的右頂點為原點。屏幕寬所在的那條線為y軸,屏幕高所在的線為x軸 let x = ((SCREENHeight - QRCodeWidth - topViewHeight) / 2.0) / SCREENHeight let y = ((SCREENWidth - QRCodeWidth) / 2.0) / SCREENWidth let width = QRCodeWidth / SCREENHeight let height = QRCodeWidth / SCREENWidth output?.rectOfInterest = CGRect(x: x, y: y, width: width, height: height)
六、設置掃碼支持的編碼格式(如下設置條形碼和二維碼兼容)
output?.metadataObjectTypes = [AVMetadataObjectTypeQRCode, AVMetadataObjectTypeEAN13Code, AVMetadataObjectTypeEAN8Code, AVMetadataObjectTypeCode128Code]
七、開始捕獲
preview = AVCaptureVideoPreviewLayer(session: session) preview?.videoGravity = AVLayerVideoGravityResizeAspectFill preview?.frame = self.view.layer.bounds self.view.layer.insertSublayer(preview!, at: 0) session?.startRunning()
掃描動畫
這里的動畫是仿支付寶的掃描框動畫
我們新建一個方法,專門處理我們的動畫。
fileprivate func scanAnimation() -> CABasicAnimation {
let scanNetAnimation = CABasicAnimation()
// 沿Y軸運動
scanNetAnimation.keyPath = "transform.translation.y"
// 掃描框的高度,注意:這里是實際高度的相反數(shù)
scanNetAnimation.byValue = QRCodeWidth
// 動畫的持續(xù)時間
scanNetAnimation.duration = 1.5
// 動畫的重復次數(shù)
scanNetAnimation.repeatCount = MAXFLOAT
return scanNetAnimation
}
使用動畫:
我們在創(chuàng)建界面的時候,掃描框有一個UIImageView,我們需要將我們的動畫添加到這個ImageView上面。
scanImageView?.layer.add(scanAnimation(), forKey: nil)
掃描之后的處理
func captureOutput(_ captureOutput: AVCaptureOutput!, didOutputMetadataObjects metadataObjects: [Any]!, from connection: AVCaptureConnection!) {
if metadataObjects.count > 0 {
session?.stopRunning()
let metadataObject = metadataObjects[0] as AnyObject
let stringValue: String = metadataObject.stringValue
let vc = QRCodeResultViewController.instantiate()
vc.resultStr = stringValue
self.navigationController?.pushViewController(vc, animated: true)
}
}
點擊掃描結果的處理
func webView(_ webView: UIWebView, shouldStartLoadWith request: URLRequest, navigationType: UIWebViewNavigationType) -> Bool {
let requestURL = request.url
if requestURL?.scheme == "http" || requestURL?.scheme == "https" || requestURL?.scheme == "mailto" && navigationType == .linkClicked {
// UIApplication.shared.open(requestURL!, options: [:], completionHandler: nil)
let svc = SFSafariViewController(url: requestURL!)
self.present(svc, animated: true, completion: nil)
}
return true
}
我們可以用
open func open(_ url: URL, options: [String : Any] = [:], completionHandler completion: ((Bool) -> Swift.Void)? = nil)
在Safari中打開連接。不過最好是把事件控制在自己的程序中,在iOS 9 之后,蘋果引入了 SFSafariViewController 這個類,可以用這個類來顯示需要瀏覽的網(wǎng)頁。
let svc = SFSafariViewController(url: requestURL!) self.present(svc, animated: true, completion: nil)
以上所述是小編給大家介紹的iOS 原生實現(xiàn)掃描二維碼和條形碼功能限制掃描區(qū)域,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
iOS中使用schema協(xié)議調(diào)用APP和使用iframe打開APP的例子
這篇文章主要介紹了iOS中使用schema協(xié)議調(diào)用APP和使用iframe打開APP的例子,用在瀏覽器中打開APP,需要的朋友可以參考下2014-08-08
iOS應用開發(fā)中UITableView的分割線的一些設置技巧
這篇文章主要介紹了iOS應用開發(fā)中UITableView分割線的一些設置技巧,包括消除分割線的方法,示例代碼為傳統(tǒng)的Objective-C語言,需要的朋友可以參考下2016-03-03
iOS開發(fā)實戰(zhàn)之Label全方位對齊的輕松實現(xiàn)
這篇文章主要給大家介紹了關于iOS開發(fā)實戰(zhàn)之輕松實現(xiàn)Label全方位對齊的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-10-10

