iOS 原生的二维码识别很是之棒,反正比 ZXing 和 ZBar 效果都好些,因此之后打算尽可能用原生的二维码识别,而后最近把原生的二维码生成也顺便作了一遍,而且在原有基础上加了一些样式参数,封了一个小库方便之后使用。git
项目地址:github.com/EyreFree/EF…github
EFQRCode 是一个用 Swift 编写的用来生成和识别二维码的库,基于 CoreImage 进行开发。swift
支持 iOS / macOS / tvOS 平台,支持 CocoaPods / Carthage / SPM 集成。数组
![]() |
![]() |
![]() |
![]() |
---|---|---|---|
![]() |
![]() |
![]() |
![]() |
你能够点击下方的 App Store 按钮从应用商店下载示例程序,支持 iOS 和 tvOS:xcode
你也能够点击下方的 Mac App Store 按钮下载 macOS 示例程序:ruby
git clone
命令下载本仓库, Examples
目录包含了全部的示例程序;或执行如下命令:bash
git clone git@github.com:EyreFree/EFQRCode.git; cd EFQRCode/Examples/iOS; open 'iOS Example.xcodeproj'
复制代码
版本 | 需求 |
---|---|
1.x | XCode 8.0+ Swift 3.0+ iOS 8.0+ / macOS 10.11+ / tvOS 9.0+ |
4.x | XCode 9.0+ Swift 4.0+ iOS 8.0+ / macOS 10.11+ / tvOS 9.0+ |
EFQRCode 能够经过 CocoaPods 进行获取。只须要在你的 Podfile 中添加以下代码就能实现引入:微信
pod "EFQRCode", '~> 4.1.0'
复制代码
而后,执行以下命令便可:app
$ pod install
复制代码
Carthage 是一个去中心化的依赖管理器,它为咱们构建依赖并经过提供二进制 Frameworks 的方式供咱们使用。工具
你能够经过 Homebrew 使用以下命令来安装 Carthage:
$ brew update
$ brew install carthage
复制代码
经过在你的 Cartfile
添加以下语句能够将 EFQRCode 引入你的项目:
github "EyreFree/EFQRCode" ~> 4.1.0
复制代码
接下来执行 carthage update
命令生成 Framework 而且将生成的 EFQRCode.framework
拖入工程便可。
Swift Package Manager 是一个集成在 swift
编译器中的用来进行 Swift 代码自动化发布的工具。
若是你已经创建了你的 Swift 包,将 EFQRCode 加入依赖是十分容易的,只须要将其添加到你的 Package.swift
文件的 dependencies
项中便可:
dependencies: [
.Package(url: "https://github.com/EyreFree/EFQRCode.git", Version(4, 1, 0))
]
复制代码
在你须要使用的地方添加以下代码引入 EFQRCode 模块:
import EFQRCode
复制代码
获取图片中所包含的二维码,同一张图片中可能包含多个二维码,因此返回值是一个字符串数组:
if let testImage = UIImage(named: "test.png")?.toCGImage() {
if let tryCodes = EFQRCode.recognize(image: testImage) {
if tryCodes.count > 0 {
print("There are \(tryCodes.count) codes in testImage.")
for (index, code) in tryCodes.enumerated() {
print("The content of \(index) QR Code is: \(code).")
}
} else {
print("There is no QR Codes in testImage.")
}
} else {
print("Recognize failed, check your input image!")
}
}
复制代码
根据所输入参数建立各类艺术二维码图片,快速使用方式以下:
// content: 二维码内容
// size (Optional): 二维码宽高
// backgroundColor (Optional): 二维码背景色
// foregroundColor (Optional): 二维码前景色
// watermark (Optional): 水印图
复制代码
if let tryImage = EFQRCode.generate(
content: "https://github.com/EyreFree/EFQRCode",
watermark: UIImage(named: "WWF")?.toCGImage()
) {
print("Create QRCode image success: \(tryImage)")
} else {
print("Create QRCode image failed!")
}
复制代码
结果:
可经过 EFQRCode 的类方法 generateWithGIF 来建立 GIF 二维码,使用方式以下:
// data: 输入的 GIF 图片的数据
// generator: 一个用来获取设置的 EFQRCodeGenerator 对象
// pathToSave (Optional): 用来存储 GIF 的路径,默认不填的话会存储在临时路径
// delay (Optional): 输出的动态 QRCode 的帧间延时,默认不填的话从输入的 GIF 图片获取
// loopCount (Optional): 输出的动态 QRCode 的循环次数,默认不填的话从输入的 GIF 图片获取
复制代码
if let qrcodeData = EFQRCode.generateWithGIF(data: data, generator: generator) {
print("Create QRCode image success.")
} else {
print("Create QRCode image failed!")
}
复制代码
你能够经过查看 Demo 代码的方式来获取更多信息,结果预览:
详情可参见具体使用文档:github.com/EyreFree/EF…
magnificatio
替代 size
,或适当提升它们的数值;Issue
和 Pull request
都是受欢迎的。备注的备注:好用的话能够给个星星
,蟹蟹,QAQ...
若有任何知识产权、版权问题或理论错误,还请指正。 https://juejin.im/post/5a3214a451882503eb4b4bed 转载请注明原做者及以上信息。