ios swift3.0实现二维码扫描、生成、识别示例代码
发布时间 - 2026-01-10 23:09:45 点击率:次基于swift3.0

1.扫描二维码
设置扫描会话,图层和输入输出
//设置捕捉设备
let device = AVCaptureDevice.defaultDevice(withMediaType: AVMediaTypeVideo)
do
{
//设置设备输入输出
let input = try AVCaptureDeviceInput(device: device)
let output = AVCaptureMetadataOutput()
output.setMetadataObjectsDelegate(self, queue: DispatchQueue.main)
//设置会话
let scanSession = AVCaptureSession()
scanSession.canSetSessionPreset(AVCaptureSessionPresetHigh)
if scanSession.canAddInput(input)
{
scanSession.addInput(input)
}
if scanSession.canAddOutput(output)
{
scanSession.addOutput(output)
}
//设置扫描类型(二维码和条形码)
output.metadataObjectTypes = [
AVMetadataObjectTypeQRCode,
AVMetadataObjectTypeCode39Code,
AVMetadataObjectTypeCode128Code,
AVMetadataObjectTypeCode39Mod43Code,
AVMetadataObjectTypeEAN13Code,
AVMetadataObjectTypeEAN8Code,
AVMetadataObjectTypeCode93Code]
//预览图层
let scanPreviewLayer = AVCaptureVideoPreviewLayer(session:scanSession)
scanPreviewLayer?.videoGravity = AVLayerVideoGravityResizeAspectFill
scanPreviewLayer?.frame = view.layer.bounds
view.layer.insertSublayer(scanPreviewLayer!, at: 0)
//自动对焦
if (device?.isFocusModeSupported(.autoFocus))!
{
do { try input.device.lockForConfiguration() } catch{ }
input.device.focusMode = .autoFocus
input.device.unlockForConfiguration()
}
//设置扫描区域
NotificationCenter.default.addObserver(forName: NSNotification.Name.AVCaptureInputPortFormatDescriptionDidChange, object: nil, queue: nil, using: {[weak self] (noti) in
output.rectOfInterest = (scanPreviewLayer?.metadataOutputRectOfInterest(for: self!.scanPane.frame))!
})
//保存会话
self.scanSession = scanSession
}
catch
{
//摄像头不可用
Tool.confirm(title: "温馨提示", message: "摄像头不可用", controller: self)
return
}
开始扫描
if !scanSession.isRunning
{
scanSession.startRunning()
}
扫描结果在代理方法中
//扫描捕捉完成
extension ScanCodeViewController : AVCaptureMetadataOutputObjectsDelegate
{
func captureOutput(_ captureOutput: AVCaptureOutput!, didOutputMetadataObjects metadataObjects: [Any]!, from connection: AVCaptureConnection!)
{
//停止扫描
self.scanLine.layer.removeAllAnimations()
self.scanSession!.stopRunning()
//播放声音
Tool.playAlertSound(sound: "noticeMusic.caf")
//扫完完成
if metadataObjects.count > 0
{
if let resultObj = metadataObjects.first as? AVMetadataMachineReadableCodeObject
{
Tool.confirm(title: "扫描结果", message: resultObj.stringValue, controller: self,handler: { (_) in
//继续扫描
self.startScan()
})
}
}
}
}
2.二维码生成
通过滤镜生成CGImage
//2.二维码滤镜
let contentData = self.data(using: String.Encoding.utf8)
let fileter = CIFilter(name: "CIQRCodeGenerator")
fileter?.setValue(contentData, forKey: "inputMessage")
fileter?.setValue("H", forKey: "inputCorrectionLevel")
let ciImage = fileter?.outputImage
//3.颜色滤镜
let colorFilter = CIFilter(name: "CIFalseColor")
colorFilter?.setValue(ciImage, forKey: "inputImage")
colorFilter?.setValue(CIColor(cgColor: QRCodeColor.cgColor), forKey: "inputColor0")// 二维码颜色
colorFilter?.setValue(CIColor(cgColor: QRCodeBgColor.cgColor), forKey: "inputColor1")// 背景色
//4.生成处理
let outImage = colorFilter!.outputImage
let scale = QRCodeSize / outImage!.extent.size.width;
let transform = CGAffineTransform(scaleX: scale, y: scale)
let transformImage = colorFilter!.outputImage!.applying(transform)
通过CGImage生成UIImage
let image = UIImage(ciImage: ciImage)
绘制Logo和边框
// 绘制logo
UIGraphicsBeginImageContextWithOptions(image.size, false, UIScreen.main.scale)
image.draw(in: CGRect(x: 0, y: 0, width: image.size.width, height: image.size.height))
//线框
let logoBorderLineImagae = QRCodeLogo.getRoundRectImage(size: logoWidth, radius: radius, borderWidth: borderLineWidth, borderColor: borderLineColor)
//边框
let logoBorderImagae = logoBorderLineImagae.getRoundRectImage(size: logoWidth, radius: radius, borderWidth: boderWidth, borderColor: borderColor)
logoBorderImagae.draw(in: logoFrame)
let QRCodeImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
封装接口:
/**
1.生成二维码
- returns: 黑白普通二维码(大小为300)
*/
func generateQRCode() -> UIImage
/**
2.生成二维码
- parameter size: 大小
- returns: 生成带大小参数的黑白普通二维码
*/
func generateQRCodeWithSize(size:CGFloat?) -> UIImage
/**
3.生成二维码
- parameter logo: 图标
- returns: 生成带Logo二维码(大小:300)
*/
func generateQRCodeWithLogo(logo:UIImage?) -> UIImage
/**
4.生成二维码
- parameter size: 大小
- parameter logo: 图标
- returns: 生成大小和Logo的二维码
*/
func generateQRCode(size:CGFloat?,logo:UIImage?) -> UIImage
/**
5.生成二维码
- parameter size: 大小
- parameter color: 颜色
- parameter bgColor: 背景颜色
- parameter logo: 图标
- returns: 带Logo、颜色二维码
*/
func generateQRCode(size:CGFloat?,color:UIColor?,bgColor:UIColor?,logo:UIImage?) -> UIImage
/**
6.生成二维码
- parameter size: 大小
- parameter color: 颜色
- parameter bgColor: 背景颜色
- parameter logo: 图标
- parameter radius: 圆角
- parameter borderLineWidth: 线宽
- parameter borderLineColor: 线颜色
- parameter boderWidth: 带宽
- parameter borderColor: 带颜色
- returns: 自定义二维码
*/
func generateQRCode(size:CGFloat?,color:UIColor?,bgColor:UIColor?,logo:UIImage?,radius:CGFloat,borderLineWidth:CGFloat?,borderLineColor:UIColor?,boderWidth:CGFloat?,borderColor:UIColor?) -> UIImage
使用
DispatchQueue.global().async {
let image = content.generateQRCodeWithLogo(logo: self.logoImageView.image)
DispatchQueue.main.async(execute: {
self.QRCodeImageView.image = image
})
}
3.识别二维码
通过CIDetector识别二维码
CIDetector用于分析CIImage,以得到CIFeature,每个CIDetector都要用一个探测器类型(NSString)来初始化。这个类型用于告诉探测器要找什么特征
1.识别图片二维码
func recognizeQRCode() -> String?
{
let detector = CIDetector(ofType: CIDetectorTypeQRCode, context: nil, options: [CIDetectorAccuracy : CIDetectorAccuracyHigh])
let features = detector?.features(in: CoreImage.CIImage(cgImage: self.cgImage!))
guard (features?.count)! > 0 else { return nil }
let feature = features?.first as? CIQRCodeFeature
return feature?.messageString
}
使用实例
DispatchQueue.global().async {
let recognizeResult = self.sourceImage?.recognizeQRCode()
let result = recognizeResult?.characters.count > 0 ? recognizeResult : "无法识别"
DispatchQueue.main.async {
Tool.confirm(title: "扫描结果", message: result, controller: self)
self.activityIndicatoryView.stopAnimating()
}
}
本文Demo地址:QRCode_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# swift3.0二维码扫描
# swift3
# 扫描二维码
# ios
# swift
# 二维码生成
# iOS和Android用同一个二维码实现跳转下载链接的方法
# IOS生成与读取二维码名片
# iOS实现二维码的扫描功能
# IOS笔记061之二维码的生成和扫描
# ios原生二维码扫描
# iOS模仿微信长按识别二维码的多种方式
# iOS 条码及二维码扫描(从相册中读取条形码/二维码)及扫码过程中遇到的坑
# iOS自带原生二维码扫描的实现
# iOS 原生实现扫描二维码和条形码功能限制扫描区域
# iOS第三方框架二维码生成与扫描
# 滤镜
# 图层
# 不可用
# 要用
# 自定义
# 要找
# 温馨提示
# 大家多多
# 自动对焦
# 背景色
# 圆角
# 无法识别
# title
# isRunning
# confirm
# startRunning
# controller
# js
# message
# return
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
大连网站制作公司哪家好一点,大连买房网站哪个好?
Laravel Session怎么存储_Laravel Session驱动配置详解
如何在橙子建站上传落地页?操作指南详解
C语言设计一个闪闪的圣诞树
大学网站设计制作软件有哪些,如何将网站制作成自己app?
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
Python函数文档自动校验_规范解析【教程】
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
Android实现代码画虚线边框背景效果
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
如何在云主机上快速搭建网站?
微信小程序 scroll-view组件实现列表页实例代码
Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】
Bootstrap整体框架之CSS12栅格系统
Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程
JS实现鼠标移上去显示图片或微信二维码
如何自定义建站之星模板颜色并下载新样式?
Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程
打造顶配客厅影院,这份100寸电视推荐名单请查收
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】
Angular 表单中正确绑定输入值以确保提交与验证正常工作
Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面
制作企业网站建设方案,怎样建设一个公司网站?
如何生成腾讯云建站专用兑换码?
如何在阿里云高效完成企业建站全流程?
Laravel如何生成URL和重定向?(路由助手函数)
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比
在线制作视频的网站有哪些,电脑如何制作视频短片?
Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】
如何快速生成专业多端适配建站电话?
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
JS碰撞运动实现方法详解
如何用虚拟主机快速搭建网站?详细步骤解析
linux top下的 minerd 木马清除方法
EditPlus中的正则表达式 实战(1)
JavaScript如何操作视频_媒体API怎么控制播放
如何在Tomcat中配置并部署网站项目?
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
Laravel如何自定义错误页面(404, 500)?(代码示例)
Python正则表达式进阶教程_复杂匹配与分组替换解析
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
网站制作免费,什么网站能看正片电影?
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
EditPlus 正则表达式 实战(3)
Laravel安装步骤详细教程_Laravel环境搭建指南
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤

