日常项目开发中,经常会出现类似扫码加好友、扫码登录或者扫码支付等功能。SWQRCode
高仿微信扫一扫功能,支持二维码/条码扫描,相册二维码/条码识别、手电筒等功能,且同时支持Swift 以及 OC 版本,欢迎 Star !!!
OC 版本:
SWQRCode_Objc
Swift 版本:
SWQRCode_Swift
1. 前言
SWQRCode
支持二维码/条码扫描,相册二维码/条码识别、手电筒等功能。舍弃了 NSTimer
而采用 CABasicAnimation
实现扫一扫动画效果。
在项目中使用 SWQRCode
,只需将 SWQRCode
文件夹拖入项目中,并在 info.plist
文件中添加 Privacy - Photo Library Usage Description
以及 Privacy - Camera Usage Description
配置,声明需要使用相机相册权限,请使用真机进行测试。
2. SWQRCodeConfig
SWQRCodeConfig
为 SWQRCode
配置文件,可配置扫一扫主题色以及扫一扫支持扫码类型。
/**
扫描器类型
- SWScannerTypeQRCode: 仅支持二维码
- SWScannerTypeBarCode: 仅支持条码
- SWScannerTypeBoth: 支持二维码以及条码
*/
typedef NS_ENUM(NSInteger, SWScannerType) {
SWScannerTypeQRCode,
SWScannerTypeBarCode,
SWScannerTypeBoth,
};
在跳转扫一扫界面前,可先进行相关配置,如下:
SWQRCodeConfig *config = [[SWQRCodeConfig alloc]init];
config.scannerType = SWScannerTypeBoth;
SWQRCodeViewController *qrcodeVC = [[SWQRCodeViewController alloc]init];
qrcodeVC.codeConfig = config;
[self.navigationController pushViewController:qrcodeVC animated:YES];
3. 添加 ActivityIndicator
若对扫描结果需要解析或者网络请求,可通过快捷添加或移除ActivityIndicator指示器。
添加 ActivityIndicator
[self.scannerView sw_addActivityIndicator];
移除 ActivityIndicator
[self.scannerView sw_removeActivityIndicator];
4. 扫一扫 Api
最后介绍一下如何处理扫描结果以及扫描异常。在项目中主要提供了两个处理扫描结果及异常的 Api。
/**
处理扫一扫结果
@param value 扫描结果
*/
- (void)sw_handleWithValue:(NSString *)value {
NSLog(@"sw_handleWithValue === %@", value);
}
value
为解析二维码/条码得出的结果,只需在此对该扫描结果根据需求做相应处理即可。
/**
相册选取图片无法读取数据
*/
- (void)sw_didReadFromAlbumFailed {
NSLog(@"sw_didReadFromAlbumFailed");
}
在识别相册图片中二维码/条码时,若无法解析成功,则会调用以上方法。