温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-07-27 20:41:38 来源:网络 阅读:1850 作者:EyreFree 栏目:移动开发

iOS 原生的二维码识别非常之棒,反正比 ZXing 和 ZBar 效果都好些,所以以后打算尽量用原生的二维码识别,然后最近把原生的二维码生成也顺便做了一遍,并且在原有基础上加了一些样式参数,封了一个小库方便以后使用。

项目地址:https://github.com/EyreFree/EFQRCode


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

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

  • 生成:利用输入的水印图/图标等资源生成各种艺术二维码;

  • 识别:识别率比 iOS 原生二维码识别率更高。

一. 效果预览

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

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

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

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

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

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

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

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

二. 示例

执行以下命令:

git clone git@github.com:EyreFree/EFQRCode.git; cd EFQRCode/Example; pod install; open EFQRCode.xcworkspace

三. 环境

  • XCode 8.0+

  • Swift 3.0+

四. 安装

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

pod "EFQRCode", '~> 1.2.0'

五. 快速使用

1. 导入 EFQRCode

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

import EFQRCode
2. 二维码识别

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

if let testImage = UIImage(named: "test.png") {
    if let tryCodes = EFQRCode.recognize(p_w_picpath: 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 p_w_picpath!")
    }
}
3. 二维码生成

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

// 常用参数:
//                         content: 二维码内容
// inputCorrectionLevel (Optional): 容错率
//                                  L 7%
//                                  M 15%
//                                  Q 25%
//                                  H 30%(默认值)
//                 size (Optional): 边长
//        magnification (Optional): 放大倍数
//                                  (如果 magnification 不为空,将会忽略 size 参数)
//      backgroundColor (Optional): 背景色
//      foregroundColor (Optional): 前景色
//                 icon (Optional): 中心图标
//             iconSize (Optional): 中心图标边长
//       isIconColorful (Optional): 中心图标是否为彩色
//            watermark (Optional): 水印图
//        watermarkMode (Optional): 水印图模式
//  isWatermarkColorful (Optional): 水印图是否为彩色

// 额外参数
//           foregroundPointOffset: 前景点偏移量
//                allowTransparent: 允许透明
if let tryImage = EFQRCode.generate(
    content: "https://github.com/EyreFree/EFQRCode",
    magnification: 9,
    watermark: UIImage(named: "WWF"),
    watermarkMode: .scaleAspectFill,
    isWatermarkColorful: false) {
        print("Create QRCode p_w_picpath success!")
} else {
    print("Create QRCode p_w_picpath failed!")
}

结果:

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


六. 使用指南

详情可参见具体使用文档:https://github.com/EyreFree/EFQRCode/blob/master/README_CN.md

七. 备注

  1. 请选用对比度较高的前景色和背景色组合;

  2. 想要提高生成二维码的清晰度可以选择使用 magnificatio 替代 size,或适当提高它们的数值;

  3. 放大倍数过高/边长过大/二维码内容过多可能会导致生成失败;

  4. 建议对生成的二维码进行测试后投入使用,例如微信能够扫描成功并不代表支付宝也能成功扫描,请务必根据您的具体业务需要做有针对性的测试;

  5. 若有任何问题,期待得到您的反馈,Issue 和 Pull request 都是受欢迎的。

备注的备注:好用的话可以给个星星,蟹蟹,QAQ...


本文链接:http://www.jianshu.com/p/ee0a495fd07a


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI