Skip to content

iOS native two-dimensional code generation and scanning(iOS 原生二维码生成与扫描 -> 高仿微信)

License

Notifications You must be signed in to change notification settings

mohsinalimat/SGQRCode

 
 

Repository files navigation

SGQRCode

前沿

  • v2.0.0 使用继承的思想进行二维码扫描管理(只需接收通知获取到数据即可;如果你想使用继承,那么可在 releases 中下载 v2.0.0 版本);之后使用封装的思想进行二维码扫描管理(由于使用继承,设备输入流、数据输出流、会话对象、预览图层及代理方法的代码全部书写在控制器中,导致了代码的可读性较差以及耦合性较高)

主要内容的介绍

  • 普通二维码生成

  • 彩色二维码生成

  • 带有小图标二维码生成

  • 根据光线强弱开启手电筒

  • 从相册中读取二维码

  • 扫描成功之后提示音

  • 扫描成功之后界面之间的跳转

  • 扫描界面仿微信(请根据项目需求,自行布局或调整)

  • 扫描界面可自定义(扫描线条以及网格样式)

SGQRCode 集成

  • 1、CocoaPods 导入 pod 'SGQRCode'

  • 2、下载、拖拽 “SGQRCode” 文件夹到工程中

代码介绍 (详细使用,请参考 Demo)

1、在 info.plist 中添加以下字段

  • NSCameraUsageDescription (相机权限访问)

  • NSPhotoLibraryUsageDescription (相册权限访问)

2、二维码生成

  • 普通二维码生成
imageView.image = [SGQRCodeGenerateManager SG_generateWithDefaultQRCodeData:@"https://github.com/kingsic" imageViewWidth:imageViewW];
  • logo 二维码生成
imageView.image = [SGQRCodeGenerateManager SG_generateWithLogoQRCodeData:@"https://github.com/kingsic" logoImageName:@"icon_image" logoScaleToSuperView:scale];
  • 彩色二维码生成
imageView.image = [SGQRCodeGenerateManager SG_generateWithColorQRCodeData:@"https://github.com/kingsic" backgroundColor:[CIColor colorWithRed:1 green:0 blue:0.8] mainColor:[CIColor colorWithRed:0.3 green:0.2 blue:0.4]];

3、二维码扫描

- (void)viewDidLoad {
    [super viewDidLoad];
    
    /// 扫描二维码创建
    SGQRCodeScanManager *scanManager = [SGQRCodeScanManager sharedManager];
    NSArray *arr = @[AVMetadataObjectTypeQRCode, AVMetadataObjectTypeEAN13Code, AVMetadataObjectTypeEAN8Code, AVMetadataObjectTypeCode128Code];
    // AVCaptureSessionPreset1920x1080 推荐使用,对于小型的二维码读取率较高
    [scanManager SG_setupSessionPreset:AVCaptureSessionPreset1920x1080 metadataObjectTypes:arr currentController:self];
    scanManager.delegate = self;
    
    
    /// 从相册中读取二维码方法
    SGQRCodeAlbumManager *albumManager = [SGQRCodeAlbumManager sharedManager];
    [albumManager SG_readQRCodeFromAlbumWithCurrentController:self];
    albumManager.delegate = self;
}
    • 扫面二维码的代理方法
/// 二维码扫描获取数据的回调方法
- (void)QRCodeScanManager:(SGQRCodeScanManager *)scanManager didOutputMetadataObjects:(NSArray *)metadataObjects;
    • 从相册中读取二维码的代理方法
/// 图片选择控制器取消按钮的点击回调方法
- (void)QRCodeAlbumManagerDidCancelWithImagePickerController:(SGQRCodeAlbumManager *)albumManager;

/// 图片选择控制器选取图片完成之后的回调方法
- (void)QRCodeAlbumManager:(SGQRCodeAlbumManager *)albumManager didFinishPickingMediaWithResult:(NSString *)result;

效果图

问题及解决方案

  • 若在使用 CocoaPods 安装第三方时,出现 [!] Unable to find a specification for (第三方仓库名) 提示时,打开终端先输入 pod repo remove master;执行完毕后再输入 pod setup 即可 (可能会等待一段时间)

更新介绍

  • 2016-9-30 :新增从相册中读取二维码功能

  • 2016-10-27:解决从相册中读取二维码,取消选择返回时,图层卡死问题(修改了创建扫描边框问题)

  • 2017-1-29 :对扫描二维码部分代码的封装;扫描视图布局采用 CALayer

  • 2017-2-14 :相机访问权限崩溃问题处理

  • 2017-3-21 :v2.0.0 使用继承的思想进行二维码扫描管理

  • 2017-5-16 :v2.0.5 使用封装的思想进行二维码扫描管理

  • 2017-6-26 :v2.1.0 加入 CocoaPods 管理

  • 2017-8-17 :v2.1.5 新增根据光线强弱判断是否打开手电筒

  • 2017-8-23 :v2.1.6 扫描界面使用 UIBezierPath 布局且可根据不同需求实现自定义(扫描线条以及网格样式)

Concluding remarks

About

iOS native two-dimensional code generation and scanning(iOS 原生二维码生成与扫描 -> 高仿微信)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Objective-C 99.3%
  • Ruby 0.7%