之前在项目中用的是第三方的zbar来扫描条码,但我上传到appstore时提示了一个64位编码的错误。因此,我就该用了苹果原生的类AVFoundation。AVFoundation扫描条码只能在屏幕的正中央的位置才能获取到条码信息,这也不是我要的效果。
说重点,我最终的解决方案仍然是用第三方的zbar库。只是我把libzbar.a的这样一个文件替换成了一个可以支持32位和64位的文件,在我的demo里可以下载。
最终既可以上传到appstore 也可以秒扫条形码。
截下来就谈谈怎样使用这个第三方库
1.把下载的第三方库导入工程中
2.添加系统的依赖库
3.和其他的开发不同的是,我使用的是ZBarReaderView这样一个对象。我已经在xib中初始化了ZBarReaderView对象,后续代码看到的_reader就是这个对象。首先在app delegate中的didFinishLaunchingWithOptions方法中添加一下代码:
[ZBarReaderView class];
4.我用到的第三方类是ZBarReaderView,核心代码:
- (void)viewDidAppear:(BOOL)animated {
[super viewDidAppear:YES];
[_reader start];
[self setupCamera];
if (self.timer) {
[self.timer invalidate];
}
self.timer = [NSTimer scheduledTimerWithTimeInterval:.02 target:self selector:@selector(animation1) userInfo:nil repeats:YES];
}
-(void)viewDidDisappear:(BOOL)animated {
[super viewDidDisappear:YES];
[_reader stop];
[self.timer invalidate];
}
- (void)viewDidLoad {
[super viewDidLoad];
//添加一个button,方便我们调整界面
_reader.readerDelegate = self;
_reader.torchMode = 0;
[self setSubviews];
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(cameraIsReady:)
name:AVCaptureSessionDidStartRunningNotification object:nil];
UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
btn.frame = CGRectMake(0, 200, 150, 150);
[btn setTitle:@"重新扫描" forState:UIControlStateNormal];
[btn addTarget:self action:@selector(btnClick) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:btn];
self.labelShow = [[UILabel alloc] initWithFrame:CGRectMake(0, 350, self.view.frame.size.width, 20)];
self.labelShow.textColor = [UIColor redColor];
self.labelShow.textAlignment = NSTextAlignmentCenter;
[self.view addSubview:self.labelShow];
}
实现它的代理方法:
- (void) readerView: (ZBarReaderView*) view didReadSymbols: (ZBarSymbolSet*) syms fromImage: (UIImage*) img{
// AudioServicesPlaySystemSound(soundID);
for(ZBarSymbol *sym in syms) {
self.labelShow.text = sym.data;
[self.timer invalidate];
[_reader stop];
break;
}
}