iOS使用Zbar扫描二维码
iOS使用Zbar扫描二维码
标签(空格分隔):二维码扫描 iOS Zbar64位
正文:
首先下载一个支持64位系统的ZbarSDK的包,保存在了我的云盘里,地址:ZbarSDK
- 把文件拖到工程里面
- 然后添加依赖库:AVFoundation.framework、libiconv.2.dylib、CoreMedia.framework、CoreVideo.framework,其中libzbar.a是SDK中的,(如果需要通过SVN上传自己代码时,要记得还有这个.a文件)
- 在你要进行添加扫描的界面的.h里 可直接复制到工程里
添加头文件
#import "ZBarSDK.h"
//设置代理
@protocol ErweimaDelegate <NSObject>
//扫描出结果则调用这个方法
-(void)finishRead:(NSString *)barCode;
@end
@interface ErweimaViewController : superVC < ZBarReaderViewDelegate > //此处superVC是自定义的父类
@property (strong, nonatomic)id < ErweimaDelegate >delegate;
@end
4.在.m文件中:
@interface ErweimaViewController ()
{
ZBarReaderView *rederView;//二维码扫描View,可自定义样式
UIImageView *lineView;//自定义的扫描线
NSTimer *time;//定时器,控制扫描线跑动
}
//在进入界面时就开始扫描
-(void)viewWillAppear:(BOOL)animated{
[super viewWillAppear:animated];
[rederView start];
}
//退出界面时就停止扫描
- (void)viewWillDisappear:(BOOL)animated
{
[super viewWillDisappear:animated];
[rederView stop];
}
-(void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
self.title = @"扫描";
[self initView];
}
- (void)initView
{
rederView = [[ZBarReaderView alloc] init];
rederView.frame = CGRectMake(0, 0,self.view.frame.size.width,self.view.frame.size.height);
rederView.readerDelegate = self;
rederView.allowsPinchZoom = NO; // 不使用Pinch手势变焦
rederView.torchMode = 0;//闪光灯 关
rederView.trackingColor = [UIColor clearColor];//锁定图码 显示的颜色框
if (TARGET_IPHONE_SIMULATOR) {
ZBarCameraSimulator *camera = [[ZBarCameraSimulator alloc] initWithViewController:self];
camera.readerView = rederView;
}
[self.view addSubview:rederView];
/*************可忽略此域中的以下代码,可以自己自定义***************/
//扫描区域计算
CGRect scanMaskRect = CGRectMake(Width_Screen/2-75, 150, 150, 150);
CGRect scanCrop=[self getScanCrop:scanMaskRect readerViewBounds:rederView.bounds];
rederView.scanCrop = scanCrop;
[rederView.captureReader captureFrame];
[rederView start];
UIImageView *image = [[UIImageView alloc] initWithFrame:CGRectMake(-20, -64, Width_Screen+40, Height_Screen)];
image.image = [UIImage imageNamed:@"111111111"];
image.backgroundColor = [UIColor clearColor];
image.alpha = 0.3;
[self.view addSubview:image];
//这里添加了类似微信的扫描线,并开始上线滑动动画
lineView=[[UIImageView alloc] initWithFrame:CGRectMake(51, 200, 219, 3)];
// lineView.image=[UIImage imageNamed:@"scan_line"];
lineView.backgroundColor = UIColor_Theme;
[self.view addSubview:lineView];
[self loadAnimationStart];
}
-(CGRect)getScanCrop:(CGRect)rect readerViewBounds:(CGRect)rvBounds{
CGFloat x,y,width,height;
x = rect.origin.y / rvBounds.size.height;
y = 1 - (rect.origin.x + rect.size.width) / rvBounds.size.width;
width = (rect.origin.y + rect.size.height) / rvBounds.size.height;
height = 1 - rect.origin.x / rvBounds.size.width;
return CGRectMake(x, y, width, height);
}
-(void)loadAnimationStart{
if(Width_Screen != 320){
[UIView animateWithDuration:2.0 animations:^{
lineView.frame=CGRectMake(lineView.frame.origin.x, 390,lineView.frame.size.width,lineView.frame.size.height);
} completion:^(BOOL finished) {
time = [NSTimer scheduledTimerWithTimeInterval:0.2 target:self selector:@selector(secStart) userInfo:nil repeats:NO];
}];
}else{
[UIView animateWithDuration:2.0 animations:^{
lineView.frame=CGRectMake(lineView.frame.origin.x, 345,lineView.frame.size.width,lineView.frame.size.height);
} completion:^(BOOL finished) {
time = [NSTimer scheduledTimerWithTimeInterval:0.2 target:self selector:@selector(secStart) userInfo:nil repeats:NO];
}];
}
}
-(void)secStart{
if(Width_Screen != 320){
lineView.frame=CGRectMake(lineView.frame.origin.x, 175,lineView.frame.size.width,lineView.frame.size.height);
if (time != nil) {
[self loadAnimationStart];
}
}else{
lineView.frame=CGRectMake(lineView.frame.origin.x, 130,lineView.frame.size.width,lineView.frame.size.height);
if (time != nil) {
[self loadAnimationStart];
NSLog(@"123");
}
NSLog(@"qwe");
}
}
-(void)readerView:(ZBarReaderView *)readerView didReadSymbols:(ZBarSymbolSet *)symbols fromImage:(UIImage *)image
{
NSString *str;//扫描出的字段,记录下来
for (ZBarSymbol *symbol in symbols) {
NSLog(@"%@", symbol.data);
str=symbol.data;
[rederView stop];
[self.navigationController popViewControllerAnimated:YES];
[self showHudMessageAndHidden:str];//展示出扫描结果,根据需求可自定义展示样式
lineView.hidden = YES;
[time setFireDate:[NSDate distantFuture]];
[time invalidate];
time = nil;
break;
}
//这个代理是 返回到上个界面把str传过去的,根据需求可改变
if([_delegate respondsToSelector:@selector(finishRead:)]){
[_delegate finishRead:str];
}
}
结束,搞定。预祝成功。
iOS使用Zbar扫描二维码的更多相关文章
- 在iOS中使用ZBar扫描二维码
最近在做的项目中需要用到二维码扫描功能,之前在Android中使用过ZXing识别二维码,ZXing也有对应的iOS版本,经过了解,ZBar也是一个常用的二维码识别软件,并分别提供了iOS和Andro ...
- 在iOS中使用ZBar扫描二维码和条形码
最近做了个外包项目,里面用到了二维码扫描和微信支付!之前比较熟悉的是ZXing,但是在Xcode7.1里面发现竟然莫名的不支持,木有办法,从网上查了一下还有一种支持二维码扫描的东西,没错就是接下来我要 ...
- 实现zbar扫描二维码的时候就把照片存储出来的办法
业务场景 当实现二维码扫描的时候(用的扫码库是zbar),有时候需要悄悄的整个扫描的照片存储下来,(charles有部分变态业务就是这样)就是说给扫描的图片照个全景照片. 那么代码如何实现 ...
- QRCode 扫描二维码、扫描条形码、相册获取图片后识别、生成带 Logo 二维码、支持微博微信 QQ 二维码扫描样式
目录 功能介绍 常见问题 效果图与示例 apk Gradle 依赖 布局文件 自定义属性说明 接口说明 关于我 功能介绍 根据之前公司的产品需求,参考 barcodescanner 改的,希望能帮助到 ...
- 制作IOS企业版App网页扫描二维码下载安装
有时候我们需要在XX网站的主页上去扫描二维码下载,那么ios开发中如何做到这一点呢. 我给大家解答一下,这也是在最近工作中用到的部分,在网上了解了一些. 下面给大家分解一下步骤: 1.Plist 和 ...
- 微信连WiFi关注公众号流程更新 解决ios微信扫描二维码不关注就能上网的问题
前几天鼓捣了一下微信连WiFi功能,设置还蛮简单的,但ytkah发现如果是ios版微信扫描微信连WiFi生成的二维码不用关注公众号就可以直接上网了,而安卓版需要关注公众号才能上网,这样就少了很多ios ...
- iOS中 扫描二维码/生成二维码详解 韩俊强的博客
最近大家总是问我有没有关于二维码的demo,为了满足大家的需求,特此研究了一番,希望能帮到大家! 每日更新关注:http://weibo.com/hanjunqiang 新浪微博 指示根视图: se ...
- ionic 扫描二维码 Barcode Scanner、QR Scanner、ZBar
1.简介 ionic 官方给我们提供了三个扫描二维码条形码插件,分别为: Barcode Scanner 样式好看,类似支付宝的扫描框.速度稍微比最后一个慢几百毫秒,主要问题是 Android 部分手 ...
- iOS中 扫描二维码/生成二维码具体解释 韩俊强的博客
近期大家总是问我有没有关于二维码的demo,为了满足大家的需求,特此研究了一番,希望能帮到大家! 每日更新关注:http://weibo.com/hanjunqiang 新浪微博 指示根视图: se ...
随机推荐
- HighCharts从数据库中读取数据
1.index.js router.get('/', function(req, res, next) { res.render('index', { title: 'Express' }); }); ...
- 从零开始编写自己的C#框架(7)——需求分析
本章内容虽然叫“需求分析”,实际上关于具体的需求分析操作步骤并没有深入去写,因为细化的话那将是一本厚厚的书,而需求分析在本系列中,是帮助大家了解项目的基本要求(主要针对本项目而已).而写本章的主要目的 ...
- First Blog
俗话说“笨鸟先飞”,遗憾的是我这只笨鸟直到今天才意识到个人博客的重要性. 原来记录下学习生活中的每一丝领悟与思考,可以让个人内在,对知识的理解得到更好的升华. 有梦的人很美,追梦的人更美.像我的座右铭 ...
- Connect(); // 2015 简要整理
去年 Connect(); 2014 Visual Studio Contact(); 直播笔记 对于我个人来说,今年 Connect(); 的三个重要发布: ASP.NET 5 RC1 Entity ...
- 用JQuery Ajax 与一般处理程序 请求数据无刷新,以及如何调试错误
通过 ajax() 与 一般处理程序,请求数据库数据,实现界面无刷新. Jquery ajax 请求参数详细说明 http://www.w3school.com.cn/jquery/ajax_ajax ...
- c# 实现简单udp数据的发送和接收
服务端代码 static void Main(string[] args) { UdpClient client = null; string receiveString = null; byte[] ...
- JS魔法堂:Data URI Scheme介绍
一.前言 上周五公司内部的Any Topic Conf.上我和同事们分享了这个主题,有同事说这个有用,有同事说这个没啥用,后来还延伸到网站性能的话题上,大家讨论的激烈程度让我觉得这次选题还不错.本篇先 ...
- android获得ImageView图片的等级
android获得ImageView图片的等级问题 要实现的功能如下图,点击分享能显示选中与不选中状态,然后发送是根据状态来实现具体分享功能. 在gridview中有5个子项,每个子元素都有两张图片A ...
- JS实现返回对象的详细信息
使用JS有时会需要打印出对象的详细信息,下面方法可以实现: function ShowObjProperty(Obj) { var PropertyList=''; var PropertyCount ...
- 代码的坏味道(4)——过长参数列(Long Parameter List)
坏味道--过长参数列(Long Parameter List) 特征 一个函数有超过3.4个入参. 问题原因 过长参数列可能是将多个算法并到一个函数中时发生的.函数中的入参可以用来控制最终选用哪个算法 ...