利用一个小demo来对二维码进行学习,总共四个界面(主界面,生成二维码界面,识别二维码界面,扫描二维码界面)
 
一.二维码的介绍
 
1.什么是二维码?
 
     二维条码/二维码是用某种特定的几何图形按一定规律在平面分布的黑白相间的图形记录数据符号信息的
     总结: 用图形记录标记一些信息,方便通过图形识别来获取信息
 
2 应用场景
     信息获取(名片、地图、WIFI密码、资料)
     手机电商(用户扫码、手机直接购物下单)
     手机支付(扫描商品二维码,通过银行或第三方支付提供的手机端通道完成支付)
     微信添加好友
 
二.二维码界面的搭建
 
1.总共四个界面,可以采用storyBoard来搭建
 
2.四个storyBoard放在一个界面,看起来不美观,还很容易搞混,有没有优化方案?
     可以把四个storyBoard分别开来,单独放到一个界面里面
 
3.怎么把storyBoard单独放在一个界面,而且还让这些界面有联系(连线)?
     可以用storyBoard reference 来解决  就是用一个引用来代替storyBoard,保持storyBoard间的联系(连线)
 
 
4.最终效果
 

三.二维码的生成
 
1.生成二维码的步骤
     1.1 创建滤镜 CIFilter
          滤镜属于CoreImage框架,要导入该框架   该框架将常用来处理图片(生成毛玻璃效果/二维码)
 
     1.2 给滤镜设置内容(用kvc方式赋值)
          内容必须为NSData类型
 
     1.3 获取生成的二维码图片
          获取的图片是CIImage类型的,使用的话要进行转换
 
 
 
2.运行程序发现生成的二维码图片很模糊,为什么?
     生成为二维码图片大小为 27 * 27 被拉伸的太大,所以不清晰
 
3.怎么显示清晰的二维码?
     苹果提供一个api(CIImage的方法)对图片放大,还不影响清晰度

  // 1.创建Transform    orginalImage的数据类型为CIImage
let scale = imageView.bounds.width / orginalImage.extent.width
let transform = CGAffineTransformMakeScale(scale, scale)
// 2.放大图片
let hdImage = orginalImage.imageByApplyingTransform(transform)
4.设置前景图片
     4.1 为什么要设置前景图片?
          一般二维码中心都有一张小的图片,就是前景图片
          生成二维码没有前景图片,需要手动添加前景图片
 
     4.2 怎么添加前景图片?
          就是把两张图片合成为一张图片,用绘图就可以轻松搞定
 
     4.3 绘图的步骤
          4.31 开启图形上下文
          4.32 将二维码图片画到图形上下文(二维码的size = 图形上下文的size)
          4.33 将前景图片画到图形上下文(前景图片的center = 图形上下文的center)
          4.34 从图形上下文获取新的图片
          4.35 关闭图形上下文
 
四.二维码的识别
 
1.获取相册中的二维码
 
     1.1 怎么获取相册?
          1.11 创建照片选择控制器
          1.12 设置照片的来源类型
          1.13 设置代理
          1.14 弹出控制器
         // 1.创建照片选择控制器
let ipc = UIImagePickerController()
// 2.设置来源的类型
ipc.sourceType = .PhotoLibrary
// 3.设置代理
ipc.delegate = self
// 4.弹出控制器
presentViewController(ipc, animated: true, completion: nil) 在代理方法中实现 选中图片dismiss掉控制器
func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : AnyObject]) {
//选中照片
imageView.image = info[UIImagePickerControllerOriginalImage] as? UIImage picker.dismissViewControllerAnimated(true, completion: nil)
}
2.识别二维码的步骤
     2.1 创建 CIDetector对象(识别器)
     2.2 获取图片,并将图片转成 CIIImage
     2.3 识别图片中的二维码(得到一个数组,图片中可能有多个二维码)
     2.4 遍历数组
       // 1.创建识别器
let detector = CIDetector(ofType: CIDetectorTypeQRCode, context: nil, options: nil) // 2.获取图片,并且将图片转成CIIImage
let image = imageView.image!
guard let ciImage = CIImage(image: image) else {
return
}
// 3.识别图片中二维码
let features = detector.featuresInImage(ciImage) // 4.遍历数组中所有的元素
for f in features {
// feature类型是CIFeature 要转换成二维码类型 CIQRCodeFeature
guard let qrCodeF = f as? CIQRCodeFeature else {
continue
}
//打印二维码的信息
print(qrCodeF.messageString)
}
 
五.扫描二维码(需要真机操作)
 
1.扫描二维码界面搭建
    1.1 主要就是扫描框的搭建
          扫描框中再加上一个ImageView,给ImageView一个动画   模拟正在扫描(冲击波)
 
     1.2 扫描框是一张图片,冲击波也是一张图片,他们的位置和尺寸是一样的
          为了方便以后更改控件的位置,可以用一个view把扫描框和冲击波封装在里面
 
     1.3 扫描动画(冲击波)动画怎么做?
          1.31 设置冲击波的底部约束相对于父控件(view)有一个间距
          1.32 更改约束的间距,来达到动画的效果
        // 1.改变约束(原来约束为-240)
scanViewBottomCons.constant =
// 2.执行动画
UIView.animateWithDuration(1.0) {
UIView.setAnimationRepeatCount(MAXFLOAT)
self.qrCodeView.layoutIfNeeded()
}
 
2.扫描二维码
     2.1 扫描步骤
          2.11 创建捕捉会话(需要导入AVFoundation框架)
          2.12 设置输入(摄像头)
          2.13 设置输出 Metadata
          2.14 添加预览图层(可以没有)
               预览图层是为了让用户知道扫描到哪里了,一般为了用户体验,都会添加
          2.15 开始扫描
 
源代码:建议不要死记,用的时候直接拷贝
         // 1.创建捕捉会话
let session = AVCaptureSession() // 2.设置输入(摄像头)
let device = AVCaptureDevice.defaultDeviceWithMediaType(AVMediaTypeVideo)
guard let input = try? AVCaptureDeviceInput(device: device) else {
return
}
session.addInput(input) // 3.设置输出(Metadata)
let output = AVCaptureMetadataOutput()
// 设置代理
output.setMetadataObjectsDelegate(self, queue: dispatch_get_main_queue())
session.addOutput(output)
// 设置output的输出的类型(该类型的设置必须在添加到session之后)
output.metadataObjectTypes = [AVMetadataObjectTypeQRCode] // 4.添加预览图层(可以没有)
let previewLayer = AVCaptureVideoPreviewLayer(session: session)
previewLayer.frame = view.bounds
view.layer.insertSublayer(previewLayer, atIndex: ) // 5.开始扫描
session.startRunning()
 
3.获取扫描结果
 3.1设置代理,在代理方法中拿到结果
          代理方法
func captureOutput(captureOutput: AVCaptureOutput!, didOutputMetadataObjects metadataObjects: [AnyObject]!, fromConnection connection: AVCaptureConnection!) {
guard let objc = metadataObjects.last as? AVMetadataMachineReadableCodeObject else {
return
}
print(objc.stringValue)
}
 
5.设置扫描区域.
 5.1 为什么要设置扫描区域?
     扫描二维码,发现只要二维码进入摄像头区域,就能直接扫描
     要求是进入扫描框,才进行扫描
 
5.2 怎么设置扫描区域?
     通过设置 output.rectOfInterest属性来设置扫描区域

     // 设置扫描的区域
let screenW = UIScreen.mainScreen().bounds.width
let screenH = UIScreen.mainScreen().bounds.height
let x : CGFloat = qrCodeView.frame.origin.x / screenW
let y : CGFloat = qrCodeView.frame.origin.y / screenH
let w : CGFloat = qrCodeView.frame.width / screenW
let h : CGFloat = qrCodeView.frame.height / screenH
output.rectOfInterest = CGRect(x: y, y: x, width: h, height: w)

注意:扫描区域的坐标系与屏幕的坐标系正好相反  ( 扫描区域x = 屏幕坐标系 y)

 
5.3 设置扫描区域代码写到哪里?
     扫描区域属于 输出的一个属性,应该写到创建输出代码的后边
 
下载源代码点击这里: 源代码链接
 

ios-深度解析二维码的生成与使用的更多相关文章

  1. iOS系统原生 二维码的生成、扫描和读取(高清、彩色)

    由于近期工作中遇到了个需求:需要将一些固定的字段 在多个移动端进行相互传输,所以就想到了 二维码 这个神奇的东东! 现在的大街上.连个摊煎饼的大妈 都有自己的二维码来让大家进行扫码支付.可见现在的二维 ...

  2. Android zxing 解析二维码,生成二维码极简demo

    zxing 官方的代码很多,看起来很费劲,此demo只抽取了有用的部分,实现了相机预览解码,解析本地二维码,生成二维码三个功能. 简化后的结构如下: 废话少说直接上代码: BaseDecodeHand ...

  3. iOS笔记061 - 二维码的生成和扫描

    二维码 生成二维码 二维码可以存放纯文本.名片或者URL 生成二维码的步骤: 导入CoreImage框架 通过滤镜CIFilter生成二维码 1.创建过滤器 2.恢复滤镜的默认属性 3.设置内容 4. ...

  4. iOS中 扫描二维码/生成二维码详解 韩俊强的博客

    最近大家总是问我有没有关于二维码的demo,为了满足大家的需求,特此研究了一番,希望能帮到大家! 每日更新关注:http://weibo.com/hanjunqiang  新浪微博 指示根视图: se ...

  5. iOS中 扫描二维码/生成二维码具体解释 韩俊强的博客

    近期大家总是问我有没有关于二维码的demo,为了满足大家的需求,特此研究了一番,希望能帮到大家! 每日更新关注:http://weibo.com/hanjunqiang  新浪微博 指示根视图: se ...

  6. Java 条形码 二维码 的生成与解析

    Barcode简介 Barcode是由一组按一定编码规则排列的条,空符号,用以表示一定的字符,数字及符号组成的,一种机器可读的数据表示方式. Barcode的形式多种多样,按照它们的外观分类: Lin ...

  7. Android二维码的生成,解析以及扫描功能

    <1> 布局只有2个按钮,实现生成二维码和解析二维码 <Button android:layout_width="wrap_content" android:la ...

  8. Java生成与解析二维码

    1.下载支持二维码的jar包qrcode.jar和qrcode_swetake.jar, 其中qrcode_swetake.jar用于生成二维码,rcode.jar用于解析二维码,jar包下载地址(免 ...

  9. java 生成和解析二维码

    public class QRCode { /** * 解析二维码(QRCode) * @param imgPath * @return */ public static String decoder ...

随机推荐

  1. Linux第01天

    Linux第01天 1.虚拟机安装linux(centos 32bit) 1.1 虚拟机安装前置工作的准备,如内存.硬盘.CPU分配.镜像下载等 1.2 安装方式(图形界面或者命令行 推荐图形界面即直 ...

  2. RobotFramework自动化测试之脚本编写(一)

    接触了上一篇的RF环境搭建及安装,相比大家都会觉得,哇塞,为什么要做这么多,那么复杂?装那么多干什么有什么用?写脚本会不会也很复杂? 其实首次安装的话 会觉得有点蒙,也不知道安装那么多是拿来干什么的, ...

  3. Linux学习笔记(3)-常用命令

    江湖传言,Linux和Windows不同,他主要的用途是在一些服务器,或者片内系统上,所以人机交互界面自然就没有Windows那么漂亮,其实也没有那个必要. 所以,学习Linux的第一步,就是学习他那 ...

  4. 命名函数、eval创建局部变量

    1.命名函数 var f = function double(){return x *2;} 该语句将函数绑定到变量f,而不是变量double 匿名的函数表达式: var f = function(x ...

  5. Node.js-部署【1】-防火墙端口的配置

    原来以为,Node.js部署以后,要手动配置防火墙端口,结果不需要,外网可以访问,看来是自动配好了,真是考虑周到,给我一个大大的惊喜.

  6. 【BFS】POJ 2251

    POJ 2251 Dungeon Master 题意:有一个地图,三维,走的方向是上下,左右,前后.问你最小步数从起始点走到出口. 思路:三维的BFS,就是多加一组状态,需要细心(不细心如我就找了半个 ...

  7. C# WinForm 慎用 override CreateParams 来重载窗体的一些特性

    窗体和控件的属性CreateParams(这真的是一个属性)很神奇,因为通过它你能够很方便的控制窗体或控件诸如边框.最大化最小化关闭按钮的隐藏.窗体的模式化弹窗模式等的一些特性.虽然,CreatePa ...

  8. 自定义一个字母Button

    package com.example.administrator.yunstore.widget; import android.content.Context; import android.gr ...

  9. HDU1426 DFS

    Sudoku Killer Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  10. 基于Jquery的页面过渡效果(原创)

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat=&qu ...