iOS 二维码,条形码扫描

由于下一个项目可能需要使用到二维码和条形码的扫描功能,之前也没搞过,所以也就找找资料,先做下个充电先。

二维码扫描的,有2个开源的库可以使用 ZBarSDK和ZXing,我采用的是ZBarSDK,ZXing的使用应该也是大同小异。

1. 首先先去   https://github.com/bmorton/ZBarSDK 将这个开源库下载回来。

2. 用Xcode新建一个工程,然后将 ZBarSDK 里的文件添加到你的项目里。

3. 添加库文件

  AVFoundation.framework (weak)
  CoreMedia.framework (weak)
  CoreVideo.framework (weak)
   QuartzCore.framework
   libiconv.dylib


4 在你需要使用的扫描功能的界面Viewcontroller 导入  improt ZBarSDK.h 实现代理 ZBarReaderDelegate

5 添加一个 UImageivew 显示扫描到的图片内容 ,UIbutton 用于响应扫描

代码如下:

    imageview = [[UIImageView alloc] initWithFrame:CGRectMake(10, 30, 300, 300)];
 
    [self.view addSubview:imageview];
    
    
    UIButton * button = [UIButton buttonWithType:UIButtonTypeCustom];
    [button setTitle:@"扫描" forState:UIControlStateNormal];
    [button setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
    [button setFrame:CGRectMake(100, 350, 100, 50)];
    [button addTarget:self action:@selector(OnClick:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:button]; 

 

-(void)OnClick:(UIButton *)btn

{

    ZBarReaderViewController * reader = [ZBarReaderViewController new];

    reader.readerDelegate = self;

    ZBarImageScanner * scanner = reader.scanner;

    [scanner setSymbology:ZBAR_I25 config:ZBAR_CFG_ENABLE to:0];

    reader.showsZBarControls = YES;

    [self presentViewController:reader animated:YES completion:nil];

}



-(void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info


{

   

    id<NSFastEnumeration> results = [info objectForKey:ZBarReaderControllerResults];

   

    ZBarSymbol * symbol;

  

    for(symbol in results)

      

        break;

    

    imageview.image = [info objectForKey:UIImagePickerControllerOriginalImage];

    

    [picker dismissViewControllerAnimated:YES completion:nil];

    NSLog(@" 扫描到的内容 =====  %@  ", symbol.data);

    

}


运行,搞定。哈哈,做个记录,以后用到也不用到处找。

====================================================华丽分割线==========================================================================

机会是给有准备的人的,刚搞完demo一个星期,新来的项目刚好需要用到此功能,不过需要自定义扫描区域,下面就是我实现的方法,网上也有很多,当是记录吧。


ZBarReaderView *readerView = [[ZBarReaderView alloc]init];
    readerView.frame =CGRectMake(0,0, self.view.frame.size.width,self.view.frame.size.height);
    readerView.readerDelegate =self;
    //关闭闪光灯
    readerView.torchMode =0;
    //扫描区域
    CGRect scanMaskRect = CGRectMake(10, 150, 200, 100);
    
    //处理模拟器
    if (TARGET_IPHONE_SIMULATOR) {
        ZBarCameraSimulator *cameraSimulator
        = [[ZBarCameraSimulator alloc]initWithViewController:self];
        cameraSimulator.readerView = readerView;
    }
    [self.view addSubview:readerView];
    [self.view sendSubviewToBack:readerView];
    //扫描区域计算
    readerView.scanCrop = [self getScanCrop:scanMaskRect readerViewBounds:readerView.bounds];
   
    [readerView start];



-(CGRect)getScanCrop:(CGRect)rect readerViewBounds:(CGRect)readerViewBounds
{
    CGFloat x,y,width,height;
    x = rect.origin.x / readerViewBounds.size.width;
    y = rect.origin.y / readerViewBounds.size.height;
    width = rect.size.width / readerViewBounds.size.width;
    height = rect.size.height / readerViewBounds.size.height;
 
    return CGRectMake(x, y, width, height);
}

最后实现代理


- (void)readerView:(ZBarReaderView *)readerView didReadSymbols:(ZBarSymbolSet *)symbols fromImage:(UIImage *)image
{
    for (ZBarSymbol *symbol in symbols) {
        NSLog(@"扫描结果  %@", symbol.data);
        break;
    }
    [readerView stop];
    [self dismissViewControllerAnimated:YES completion:nil];
}


搞定,如果需要类似微信的效果,自己再扫描区域上再加个图片和弄个线的动画就好了,我就是这么干的,哈哈。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值