Skip to content
forked from kingsic/SGQRCode

Generation and scanning of iOS native two-dimensional code (QRCode、bar Code)(iOS 原生二维码生成与扫描 -> 高仿微信)

License

Notifications You must be signed in to change notification settings

Tdreamy/SGQRCode

 
 

Repository files navigation

前沿

  • 在此首先感谢那些曾经对 SGQRCode 提出宝贵建议者

  • 这是对iOS原生二维码生成与扫描的总结 (之所以在此做总结:是为了方便更多的人去很好的使用iOS原生二维码生成与扫描的这块知识点)

  • v2.0 采用的是继承,只需接收通知(拿到数据做处理)即可,如果你想使用继承,那么可在 releases 中下载 v2.0 版本;最新的版本采用封装思想(由于 v2.0 采用的继承,代码耦合性比较高且设备输入流、数据输出流、会话对象、预览图层及代理方法全部写在控制器中,造成了代码的可读性较差)

主要内容的介绍

  • 普通二维码生成

  • 彩色二维码生成

  • 带有小图标二维码生成

  • 扫描二维码的自定义

  • 是否开启闪光灯

  • 从相册中获取二维码

  • 扫描成功之后提示音

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

  • 扫描二维码界面采取了微信二维码界面的布局

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

1、在 info.plist 中需添加的字段

  • NSCameraUsageDescription (相机权限访问)

  • NSPhotoLibraryUsageDescription (相册权限访问)

2、导入 SGQRCode 文件夹

  • 导入 “SGQRCode.h”

3、二维码生成

  • 普通二维码生成
imageView.image = [SGQRCodeManager SG_generateWithDefaultQRCodeData:@"https://github.com/kingsic" imageViewWidth:imageViewW];
  • logo 二维码生成
imageView.image = [SGQRCodeManager SG_generateWithLogoQRCodeData:@"https://github.com/kingsic" logoImageName:@"icon_image" logoScaleToSuperView:scale];
  • 彩色二维码生成
imageView.image = [SGQRCodeManager 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]];

4、二维码扫描

- (void)viewDidLoad {
    [super viewDidLoad];
    
    /// 扫描二维码创建
    SGQRCodeManager *manager = [SGQRCodeManager sharedQRCodeManager];
    manager.currentVC = self;
    NSArray *arr = @[AVMetadataObjectTypeQRCode, AVMetadataObjectTypeEAN13Code, AVMetadataObjectTypeEAN8Code, AVMetadataObjectTypeCode128Code];
    // AVCaptureSessionPreset1920x1080 推荐使用,对于较小的二维码识别率较高
    [manager SG_setupSessionPreset:AVCaptureSessionPreset1920x1080 metadataObjectTypes:arr];
    manager.delegate = self;
    
    /// 从相册中读取二维码方法
    [[SGQRCodeManager sharedQRCodeManager] SG_readQRCodeFromAlbum];
}
    • 扫面二维码的代理方法
- (void)manager:(SGQRCodeManager *)manager captureOutput:(AVCaptureOutput *)captureOutput didOutputMetadataObjects:(NSArray *)metadataObjects fromConnection:(AVCaptureConnection *)connection;
    • 从相册中读取二维码的代理方法
/// 取消选择照片的代理方法
- (void)manager:(SGQRCodeManager *)manager imagePickerControllerDidCancel:(UIImagePickerController *)picker;

/// 选择照片完成的代理方法
- (void)manager:(SGQRCodeManager *)manager imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary<NSString *,id> *)info;

效果图

更新介绍

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

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

  • 2017-1-29 :对扫描二维码部分代码的封装,从相册中读取二维码采用新方法;扫描视图布局采用 CALayer

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

  • 2017-3-21 :版本升级处理 (v2.0 采用继承)

  • 2017-3-27 :从相册中读取二维码照片的优化处理

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

Concluding remarks

  • 如在使用中, 遇到什么问题或有更好建议者, 请记得 Issues me[email protected] 邮箱联系我

  • 感谢邮箱号为:[email protected] 的这位朋友提供的从相册中读取二维码照片的优化方案

About

Generation and scanning of iOS native two-dimensional code (QRCode、bar Code)(iOS 原生二维码生成与扫描 -> 高仿微信)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Objective-C 100.0%