新闻资讯

新闻资讯 通知公告

iOS 花式二维码生成和二维码识别

编辑:016     时间:2020-02-09

EFQRCode 是一个用 Swift 编写的用来生成和识别二维码的库,基于 CoreImage 进行开发。

  • 生成:利用输入的水印图/图标等资源生成各种艺术二维码;
  • 识别:识别率比 iOS 原生二维码识别率更高。

支持 iOS / macOS / tvOS 平台,支持 CocoaPods / Carthage / SPM 集成。

概述

示例

应用商店

你可以点击下方的 App Store 按钮从应用商店下载示例程序,支持 iOS 和 tvOS:

你也可以点击下方的 Mac App Store 按钮下载 macOS 示例程序:

手动

  1. 利用git clone命令下载本仓库,Examples目录包含了所有的示例程序;
  2. 用 XCode 打开对应项目编译即可。

或执行以下命令:

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+

安装

CocoaPods

EFQRCode 可以通过 CocoaPods 进行获取。只需要在你的 Podfile 中添加如下代码就能实现引入:

pod "EFQRCode", '~> 4.1.0' 复制代码

然后,执行如下命令即可:

$ pod install 复制代码

Carthage

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 Package Manager 是一个集成在swift编译器中的用来进行 Swift 代码自动化发布的工具。

如果你已经建立了你的 Swift 包,将 EFQRCode 加入依赖是十分容易的,只需要将其添加到你的Package.swift文件的dependencies项中即可:

dependencies: [
    .Package(url: "https://github.com/EyreFree/EFQRCode.git", Version(4, 1, 0))
] 复制代码

快速使用

1. 导入 EFQRCode

在你需要使用的地方添加如下代码引入 EFQRCode 模块:

import EFQRCode 复制代码

2. 二维码识别

获取图片中所包含的二维码,同一张图片中可能包含多个二维码,所以返回值是一个字符串数组:

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!")
    }
} 复制代码

3. 二维码生成

根据所输入参数创建各种艺术二维码图片,快速使用方式如下:

//                    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!")
} 复制代码

结果:

4. 动态二维码

可通过 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 代码的方式来获取更多信息,结果预览:

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

回复列表

相关推荐