Flutter扫码识别二维码内容

前面一篇写了生成二维码图片,这篇来写使用相机扫描识别二维码

识别二维码需要用到插件 barcode_scan 

 

首先在 pubspec.yaml 文件中添加以下依赖,添加依赖后在 pubspec.yaml 运行 flutter packages get 或 使用IDE更新软件包。

dependencies:
  ...
  barcode_scan: ^1.0.0

  

Android配置

在使用它之前需要先配置 android\app\src\main\AndroidManifest.xml 

在该文件中添加添加app获取相机权限及BarcodeScanner activity

<!--获取相机权限-->
<uses-permission android:name="android.permission.CAMERA" />

  

<activity android:name="com.apptreesoftware.barcodescan.BarcodeScannerActivity"/>

  

如下图所示

Flutter扫码识别二维码内容

编辑项目级build.gradle文件

buildscript {
    ext.kotlin_version = '1.2.31'
    ...
    dependencies {
        ...
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
    }
}
...

  

如图所示

Flutter扫码识别二维码内容

以及编辑应用级build.gradle文件

apply plugin: 'kotlin-android'
...
dependencies {
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jre7:$kotlin_version"
    ...
}

  

如图所示

Flutter扫码识别二维码内容

 注意  apply plugin: 'kotlin-android'  需要放在  apply plugin: 'com.android.application'  之后

 

IOS配置

在 Info.plist 中添加一下内容

<key>NSCameraUsageDescription</key>
<string>Camera permission is required for barcode scanning.</string>

  

扫码实现

完成以上步骤之后在需要触发扫码的页面引用barcode_scan

import 'package:barcode_scan/barcode_scan.dart';

  

然后写上一个调用扫码的方法

//  扫描二维码
Future scan() async {
  try {
    // 此处为扫码结果,barcode为二维码的内容
    String barcode = await BarcodeScanner.scan();
    print('扫码结果: '+barcode);
  } on PlatformException catch (e) {
    if (e.code == BarcodeScanner.CameraAccessDenied) {
      // 未授予APP相机权限
      print('未授予APP相机权限');
    } else {
      // 扫码错误
      print('扫码错误: $e');
    }
  } on FormatException{
    // 进入扫码页面后未扫码就返回
    print('进入扫码页面后未扫码就返回');
  } catch (e) {
    // 扫码错误
    print('扫码错误: $e');
  }
}

  

在使用时触发scan()方法即可,效果如下

Flutter扫码识别二维码内容

默认的右上角打开闪光灯的文字为英文,如果需要修改可以到Flutter目录下修改以下相应文件

Andriod文件

flutter\.pub-cache\hosted\pub.flutter-io.cn\barcode_scan-1.0.0\android\src\main\kotlin\com\apptreesoftware\barcodescan\BarcodeScannerActivity.kt

  

如图

Flutter扫码识别二维码内容

 

IOS文件

flutter\.pub-cache\hosted\pub.flutter-io.cn\barcode_scan-1.0.0\ios\Classes\BarcodeScannerViewController.m

  

如图

Flutter扫码识别二维码内容

 

注:该插件也可以用来扫描条形码

上一篇:F与Q查询;开启事务;ORM常用的字段类型;choises参数;多对多的三种创建方式;Ajax简介 # day56


下一篇:Django的ORM查询(学生成绩查询)