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 轉載請註明原做者及以上信息。