IOS zxing 集成

转:http://blog.csdn.net/brokge/article/details/9045629

最近做Android和iOS项目用到了ZXing进行二维码扫描,其中在iOS整合比较麻烦,遇到不少问题。

文章前半部分基础部分摘自此文章:http://blog.devtang.com/blog/2012/12/23/use-zxing-library/

写的比较清楚。

后面是自己在整合过程中遇到的问题和解决方案,整合后的代码可以在附件中看到(包括,iOS和Android),在此和大家进行分享。

ZXing(Github镜像地址)是一个开源的条码生成和扫描库(开源协议为Apache2.0)。它不但支持众多的条码格式,而且有各种语言的实现版本,它支持的语言包括:Java, C++, C#, Objective-C, ActionScript和Ruby。

iOS篇

集成步骤

首先去Google Code或Github将ZXing的代码下载下来,整个工程比较大,我们只需要其中涉及iOS的部分,所以最好做一些裁剪。简单来说,我们只需要保留cpp和iphone这2个文件夹,其余的全部删掉。如下图所示:

接着我们继续裁剪,对于cpp这个目录,只保留cpp/core/src/zxing下面的内容,其余内容也可以删掉了。但是整个目录结构必须保持原样。裁剪完后,整个目录结构如下所示:

接下来,我们把裁剪后的zxing目录整个移动到我们的iOS项目的目录下,并且把上图中可以看到的ZXingWidget.xcodeproj文件拖动到我们的iOS工程中。

下一步,我们需要设置ZXing项目和我们原本的iOS项目之间的依赖关系。在我们的iOS项目的设置中,点击build phases tab,然后增加 Target Dependencies 和 Link binary,并且增加这些framework依赖:

  1. <span style="font-size: 14px;">a. AVFoundation
  2. b. AudioToolbox
  3. c. CoreVideo
  4. d. CoreMedia
  5. e. libiconv
  6. f. AddressBook
  7. g. AddressBookUI</span>

完成之后如下图所示:

最后一步,在设置中增加如下2个header search path:

  • ./zxing/iphone/ZXingWidget/Classes
  • ./zxing/cpp/core/src

需要注意的是,第一个path要设置成循环查找子目录,而第二个不循环查找,如下图所示:

恭喜你,完成这步之后,你就已经完成ZXing库的集成了。下面谈谈如何使用ZXing库来做二维码识别。

二维码识别

使用方法

ZXing直接提供了一个扫描二维码的View Controller,即ZXingWidgetController。在需要使用的界面代码中,加入文件依赖:

Cpp代码  

  1. <span style="font-size: 14px;">#import <ZXingWidgetController.h>
  2. #import <QRCodeReader.h> </span>

然后在需要扫描的时候,调用如下代码即可:

Cpp代码  

  1. <span style="font-size: 14px;">- (IBAction)scanPressed:(id)sender {
  2. ZXingWidgetController *widController = [[ZXingWidgetController alloc] initWithDelegate:self showCancel:YES OneDMode:NO];
  3. NSMutableSet *readers = [[NSMutableSet alloc ] init];
  4. QRCodeReader* qrcodeReader = [[QRCodeReader alloc] init];
  5. [readers addObject:qrcodeReader];
  6. [qrcodeReader release];
  7. widController.readers = readers;
  8. [readers release];
  9. [self presentModalViewController:widController animated:YES];
  10. [widController release];
  11. }</span>

在ZXing扫描有结果时,会调用如下回调函数:

Cpp代码  

  1. <span style="font-size: 14px;">@protocol ZXingDelegate
  2. - (void)zxingController:(ZXingWidgetController*)controller didScanResult:(NSString *)result;
  3. - (void)zxingControllerDidCancel:(ZXingWidgetController*)controller;
  4. @end</span>

遇到的问题和解决方案:

我在使用中遇到了一些问题,主要是编译的问题。

  1. 一个是找不到 头文件。解决方法:把用到ZXing的源文件扩展名由.m改成.mm。
  2. 报错:Undefined symbols for architecture armv7s,解决方法:(1)把ZXingWidget的一个build target参数:”Build Active Architecture Only” 修改成 “NO”.(2)把main.m改为main.mm
  3. 报错:No such file or directory,出现该错误可能是你的Header Search Path写错了,或者就是你的zxing库的目录结构不是我上面强调的,好好检查一下吧。
  4. 如果你需要生成二维码做测试,推荐一个不错的在线生成二维码的网站:http://cli.im/
  5. 报错:IOStream File not found,解决方案把引入ZXingWidgetController的ViewController以及AppDelegate和main也需要修改成.mm,修改完后报错:Undefined symbols for architecture i386:
      "std::string::c_str() const"修改:TARGETS -> Build Settings -> Apple LLVM compiler 4.2 - Language
    设置C++ Standard Library的值为Compiler Default
    ZXingWidget项目:
    TARGETS -> Build Settings -> Architectures
    设置Architectures的值为Standard(armv7, armv7s)
  6. 报错:clang: error: invalid deployment target for -stdlib=libc++ (requires iOS 5.0 or later):解决办法:将target 中的CLANG_CXX_LIBRARY项设置为libstdc++

ps:

1,  uint8_t* baseAddress = (uint8_t *)CVPixelBufferGetBaseAddress(imageBuffer);这种类型转换

2,c++ standard library 选择:

时间: 2024-08-25 05:24:37

IOS zxing 集成的相关文章

一步一步构建iOS持续集成:Jenkins+GitLab+蒲公英+FTP

什么是持续集成 持续集成是一种软件开发实践,即团队开发成员经常集成它们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成.每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误. 为什么使用持续集成 1.减少风险2.减少重复过程3.任何时间.任何地点生成可部署的软件4.增强项目的可见性 常用的持续集成工具 Jenkins CI Travis CI Hudson CI Circle CI 市面上的持续集成工具有很多,考虑到Jenkins的稳定性,

如何在ios中集成微信登录功能

在ios中集成微信的登录功能有两种方法 1 用微信原生的api来做,这样做的好处就是轻量级,程序负重小,在Build Settings 中这样设置 然后设置 友盟的设置同上,但是要注意,加入你需要的所有框架到应用程序中

iOS app集成支付宝支付流程及后台php订单签名处理

iOS app集成支付宝支付流程 1: 开通支付宝商户 由公司去支付宝 https://b.alipay.com/order/serviceIndex.htm 签约支付宝开通支付宝商家: 2:商户支付宝开通无线支付功能 开通商户支付宝之后,虽然可以获取到应用使用的 key和id,如果如果不开通无线支付功能的话,会在app集成的时间 提示商户未开通无线支付功能的错误: 开通商户支付宝-无线支付功能,请在商户支付宝后台,按要求提供审核材料开通: 3:在商户支付宝后台下载SDK 在商户支付宝后台,即可

李洪强iOS之集成极光推送二iOS 证书 设置指南

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px "PingFang SC"; color: #000000 } span.s1 { } span.s2 { font: 18.0px Menlo } 创建应用程序ID 登陆 iOS Dev Center 选择进入iOS Provisioning Portal. 在 iOS Provisioning Portal中,点击App IDs进入App ID列表. 创建 App ID,如果

李洪强iOS之集成极光推送一iOS SDK概述

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px "PingFang SC"; color: #000000 } span.s1 { } span.s2 { font: 18.0px Menlo } 李洪强iOS之集成极光推送一iOS SDK概述 p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #000000 } span.s1 { } JPus

iOS 持续集成

iOS 持续集成系列 - 开篇 前言 iOS 开发在经过这几年的野蛮生长之后,慢慢地趋于稳定.无论开发语言是 Objective-C 还是 Swift,工程类型是 Hybird 还是原生,开发思想是 OOP 还是函数式,随着项目逐渐变大都在面临相同的问题: 测试.发布等重复性工作占了很大一部分时间,回归成本越来越高.持续集成不可避免地被提上了日程. 本文主要阐述 iOS 下的持续集成,以目标.内容.流程.工具入手,希望可以为大家描绘一幅 iOS 持续集成的蓝图.这可能不是一篇可以让你 Step

使用 Fastlane 实现 IOS 持续集成

简介 持续集成是个“一次配置长期受益”的工作.但很多小公司都没有.以前在做Windows开发配置感觉简单一些,这次配置iOS的,感觉步骤还挺多.整理出来,分享给大家,不正确的地方请及时指正. 本文主要使用fastlane配置iOS的持续集成,自动编译.打包出多个版本. 最近转行iOS开发,首要任务是使用Jenkins(算是hudson的兄弟)配置iOS工程的持续集成. 查找各种资料后,整理出以下几个关键词. jenkins搭建. 使用fastlane中提供的工具修改工程配置. gym 或 ipa

【IOS】集成zxing(二维码扫描)

现在zxing已经到了2.2版本,以前的集成方式出了点问题.下面我做出一点修正.以前的版本的集成方法,参考:http://blog.devtang.com/blog/2012/12/23/use-zxing-library/按照以前的方式做好后  然后就是适配以下现在的版本的修改1.增加   SenTestingKit  框架 设置为Optional2.把目录 iphone/ZXingWidget 下的Tests删了3.保留目录 cpp/core/src 的bigint文件最后提醒:  设置查找

iOS中的zxing集成步骤

参照网上各大神文章,自己总结了下如下,欢迎大家指正与交流!(主参照:http://blog.csdn.net/brokge/article/details/9045629) 1. 到 github下载开源库 (https://github.com/zxing/zxing) 2. 得到代码后只需要 cpp部分和iphone部分,如下: 3. 继续剪裁 cpp 和iphone文件夹,如下: 4.将修改好的zxing文件夹全部添加到我们的目标工程中,并且把ZXingWidget.xcodeproj文件