公司很多項目是有掃描二維碼的功能的彩届,例如掃碼簽到、掃碼添加好友蹦渣、掃碼安裝相應App等等哄芜。公司項目采用了QRCodeReader這個第三方庫來處理掃碼功能,我來說一說掃碼遇到的一些問題柬唯。
一认臊、QRCodeReader本身沒有做掃描動畫的效果,所以用戶用起來會產(chǎn)生錯覺锄奢,這個東西為什么沒有微信掃碼那樣會上下動的線啊失晴,是不是失靈了,沒有用拘央,掃不了巴科ā?灰伟?拆又?E⒁拧8痔埂!
作為iOS開發(fā)人員的我募判,是不愿也不允許這樣的事故發(fā)生在我經(jīng)手的項目里挡爵。本打算使用原生二維碼AVFoundation來重新做下掃碼功能(詳情可查看大神簡書:http://www.reibang.com/p/2180e940a589 )盟萨,但是發(fā)現(xiàn)可以在QRCodeReader基礎(chǔ)上進行修改,而且QRCodeReader的簡單封裝也帶來很多便利性了讨。
解決步驟:
①在QRCodeReaderViewController.m文件里自定義configView方法,用以添加動畫背景圖片以及動畫效果制轰。
-(void)configView{
_imageView = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, 211, 211)];
_imageView.center=self.view.center;
_imageView.image = [UIImage imageNamed:@"pick_bg"];
[self.view addSubview:_imageView];
upOrdown = NO;
num =0;
_line = [[UIImageView alloc] initWithFrame:CGRectMake(self.cameraView.frame.origin.x+50, self.cameraView.frame.origin.y+100, self.cameraView.frame.size.width -100, 2)];
_line.image = [UIImage imageNamed:@"line.png"];
[self.view addSubview:_line];
timer = [NSTimer scheduledTimerWithTimeInterval:0.02 target:self selector:@selector(animation1) userInfo:nil repeats:YES];
}
-(void)animation1
{
if (upOrdown == NO) {
num ++;
_line.frame = CGRectMake(_imageView.frame.origin.x, _imageView.frame.origin.y+2*num, _imageView.frame.size.width, 2);
if (2*num >= _imageView.frame.size.height) {
upOrdown = YES;
}
}
else {
num --;
_line.frame = CGRectMake(_imageView.frame.origin.x,_imageView.frame.origin.y+2*num,_imageView.frame.size.width, 2);
if (num <= 0) {
upOrdown = NO;
}
}
}
②在QRCodeReaderViewController.m文件里- (id)initWithCancelButtonTitle:(nullable NSString *)cancelTitle codeReader:(nonnull QRCodeReader *)codeReader startScanningAtLoad:(BOOL)startScanningAtLoad showSwitchCameraButton:(BOOL)showSwitchCameraButton showTorchButton:(BOOL)showTorchButton前计;方法里調(diào)用configView方法。
- (id)initWithCancelButtonTitle:(nullable NSString *)cancelTitle codeReader:(nonnull QRCodeReader *)codeReader startScanningAtLoad:(BOOL)startScanningAtLoad showSwitchCameraButton:(BOOL)showSwitchCameraButton showTorchButton:(BOOL)showTorchButton
{
if ((self = [super init])) {
self.view.backgroundColor = [UIColor blackColor];
self.codeReader = codeReader;
self.startScanningAtLoad = startScanningAtLoad;
self.showSwitchCameraButton = showSwitchCameraButton;
self.showTorchButton = showTorchButton;
if (cancelTitle == nil) {
cancelTitle = NSLocalizedString(@"Cancel", @"Cancel");
}
[self setupUIComponentsWithCancelButtonTitle:cancelTitle];
[self setupAutoLayoutConstraints];
[_cameraView.layer insertSublayer:_codeReader.previewLayer atIndex:0];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(orientationChanged:) name:UIDeviceOrientationDidChangeNotification object:nil];
__weak typeof(self) weakSelf = self;
[codeReader setCompletionWithBlock:^(NSString *resultAsString) {
if (weakSelf.completionBlock != nil) {
weakSelf.completionBlock(resultAsString);
}
if (weakSelf.delegate && [weakSelf.delegate respondsToSelector:@selector(reader:didScanResult:)]) {
[weakSelf.delegate reader:weakSelf didScanResult:resultAsString];
}
}];
[self configView];
}
return self;
}
③到此垃杖,要做的動畫效果就完美解決了男杈。
二、近來公司準備做關(guān)于條形碼的掃描功能调俘。本來以為很簡單嘛伶棒,以前是掃碼支持的類型就只有AVMetadataObjectTypeQRCode(二維碼)旺垒,想著把AVMetadataObjectTypeEAN13Code、AVMetadataObjectTypeEAN8Code肤无、AVMetadataObjectTypeCode128Code這三種類型添加上先蒋,不就支持條形碼的掃描了嘛,想法是美好的宛渐,現(xiàn)實是殘酷的竞漾!雖然是已經(jīng)支持條形碼掃描,但是識別電腦上的條形碼是相當?shù)穆妫喼睉K不忍睹业岁!可是識別實物,例如筆記本上的條形碼寇蚊,卻反映很快笔时。查閱資料(http://www.cnblogs.com/coolcold/p/5775276.html )后,發(fā)現(xiàn)原來是焦距不夠帶來的嚴重問題仗岸。有了思路允耿,就有解決方案。
解決方案:在QRCodeReader.m文件里找到toggleTorch方法爹梁,在toggleTorch方法里放大設(shè)備的焦距即可右犹。
- (void)toggleTorch
{
NSError *error = nil;
[_defaultDevice lockForConfiguration:&error];
if (error == nil) {
AVCaptureTorchMode mode = _defaultDevice.torchMode;
_defaultDevice.torchMode = mode == AVCaptureTorchModeOn ? AVCaptureTorchModeOff : AVCaptureTorchModeOn;
}
//_defaultDevice放大焦距
if (_defaultDevice.activeFormat.videoMaxZoomFactor > 2) {
_defaultDevice.videoZoomFactor = 2;
}else{
_defaultDevice.videoZoomFactor = _defaultDevice.activeFormat.videoMaxZoomFactor;
}
[_defaultDevice unlockForConfiguration];
}
放大焦距后,識別條形碼的效率也是剛剛的姚垃。嘿嘿念链。。